수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

c언어 구조체와 리스트 관련 2문제 질문드려요 급합니다.

슬S2아

2023.04.01

질문 제목 : c언어 구조체와 리스트 관련 2문제 질문드려요 급합니다.
구조체와 리스트가 섞인 듯한 문제가 하나 있는데 이문제를 어떻게 풀어야 할지 모르겟습니다.
질문 내용 :
1. 다음 구조체 선언을 참고하여 연결 리스트(linked list) 생성, 삽입, 삭제 과정을 그림으로
표현한 후 c 언어를 이용하여 구현하시오.
struct student {
char name[20];
int stud_id;
char year;
char major[20];
//자기 참조 구조체 포인터
};
①위 구조체에 다음 구조체를 연결(link)하기 위한 포인터(자기 참조 구조체 포인터)를
추가하여 단순 연결 리스트(single linked list)를 위한 노드를 선언하시오.
②노드 s1, s2, s3, s4를 생성하고 연결하는 과정을 그림으로 표현한 후 c-like 표현법으
로 표현하시오.
③노드 s2, s3를 순차적으로 삭제하시오(s1-s4).
④새로운 노드 s5를 생성하여 노드 s1과 s4사이에 추가하시오(s1-s5-s4).
⑤새로운 노드 s6을 생성하여 연결 리스트의 맨처음 위치에 추가하시오(s6-s1-s4).
4. 다음 구조체 선언을 참고하여 연결 리스트(linked list) 생성, 삽입, 삭제 과정을 그림으로
표현한 후 c 언어를 이용하여 구현하시오.
struct student {
char name[20];
int stud_id;
char year;
char major[20];
//자기 참조 구조체 포인터
};
①위 구조체에 다음 구조체를 연결(link)하기 위한 포인터(자기 참조 구조체 포인터)를
추가하여 이중 연결 리스트(doubly linked list)를 위한 노드를 선언하시오.
②노드 s1, s2, s3, s4를 생성하고 연결하는 과정을 그림으로 표현한 후 c-like 표현법으
로 표현하시오.
③노드 s2, s3를 순차적으로 삭제하시오(s1-s4).
④새로운 노드 s5를 생성하여 노드 s1과 s4사이에 추가하시오(s1-s5-s4).
⑤새로운 노드 s6을 생성하여 연결 리스트의 맨처음 위치에 추가하시오(s6-s1-s4).

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • Emily

    저기 책을 참고 해서 풀기는 했는데요. 이중 연결 과 단순 연결의 소스가 거의 똑같나요? 아니면 선언부분에서만 다르나요? 다르면 어떻게 다른지 소스를 구조체 하나 해서 가르쳐주십시오. 부탁드립니다.

  • 로다

    저도 그건 c 언어 공부하면서 처음 들어보는 말이라 잘 모르겠네요

  • 다온

    하나만 더 묻겠습닏. 혹시 C-like표현법이 어떤건지 아시나요? 혹시 상자 그려서 그걸로 연결을 표시하는 건가요?

  • 창의적

    이중연결은 구조체 안에서 포인터를 두개 선언하고 하나는 단일과 똑같이 다음구조체에 연결하고 하나는 이전구조체에 연결합니다. 차이점은 이전구조체를 찾기가 수월하다는 겁니다.

  • 영미

    단순 연결과 이중 연결이 차이 가 있나요? 교재에 있는 그림으로는 대충 알겠는데
    선언하는 것에서 어떻게 차이가 있나요? 그리고 이거 빼고는 차이가 없나요?

  • 퐁당

    아~ 혹시 리스트 자체를 처음 보시는 건가요?
    저는 자료구조에서 배웠어요 알고리즘 부분일거에요

  • 인1형녀

    조금만더 가르쳐 주실수 있나요? 리스트가 c언어에서 어디에 해당하는 부분 인가요?

  • 알찬마루

    힌트만 드린 이유는 답은 스스로 찾아야 자기것이 된다고 생각해서 입니다. 참고로 저 문제 같은 경우는 링크드리스트의 가장 기본이 되는 것들입니다. 저 문제를 마스터 해야만 다른 알고리즘도 이해하실수 있을거에요. 주변에 잘 아는 사람이 있다면 이해될때까지 가서 배우는 걸 추천합니다. 교수님이라도 찾아가세요! 과제라면 꼭 제때 못해도 성의를 봐서라도 어느정도ㅜ점수는 받을 수 있을겁니다

  • 하예진

    좀 더 힌트를 드리자면 struct student *s1, *s2, *T가 있다면 s1-link = s2요렇게 먼저 해놓고 s1의 실제 값이 바뀌면 안되니 임시구조체변수로 T = s1 을 해두고
    T = T-link 요렇게 하면 T값에 각 노드값이 순서대로 대입이 됩니다

  • 그대와나

    구조체 안에 struct student *link를 선언한 다음에 저 link가 가르키는 주소가 또 다른 struct student구조체가 되면 됩니다.

번호 제 목 글쓴이 날짜
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
2699161 for loop안에 있는 if문 (9) Orange 2025-06-23
2699105 링크더리스트 이전 링크값 출력함수. 꼬꼬마 2025-06-23
2699078 정수를 한자리씩 배열에 담는 법은 어떻게 하나요.. (4) 귀염포텐 2025-06-22
2699024 C언어 공부하려는데 도와주세요!!! (2) 달님 2025-06-22
2698994 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) 별 2025-06-22
2698967 파일삭제 윈도우 폴더까지 접근하게하는 함수가 뭔가요 (2) 샤인 2025-06-21
2698938 c언어 메모리질문 (3) 나래 2025-06-21
2698909 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) 궁수자리 2025-06-21
2698882 프로그래밍좀 짜주세요 (3) 황예 2025-06-21
2698855 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. 꽃봄 2025-06-20
2698829 학점계산기 (7) MyWay 2025-06-20
2698782 기초적인 함수 질문이요ㅠㅠㅠㅠ 내담 2025-06-20
2698749 프로그램 짜던 도중 패닉입니다...ㅜ 파랑 2025-06-19
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com