c언어 구조체와 리스트 관련 2문제 질문드려요 급합니다.
물맑
질문 제목 : 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).
-
큰꽃들
저기 책을 참고 해서 풀기는 했는데요. 이중 연결 과 단순 연결의 소스가 거의 똑같나요? 아니면 선언부분에서만 다르나요? 다르면 어떻게 다른지 소스를 구조체 하나 해서 가르쳐주십시오. 부탁드립니다.
-
가장
저도 그건 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구조체가 되면 됩니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |