연결리스트 return문 이 궁금합니다.
새얀
#include stdio.h
#include stdlib.h
typedef struct _node
{
int key;
struct _node *next;
}node;
node *head, *tail;
void init_list(void)
{
head=(node*)malloc(sizeof(node));
tail=(node*)malloc(sizeof(node));
head-next=tail;
tail-next=tail;
}
int delete_next(node *t)
{
node *s;
if(t-next == tail)
return 0; //꼬리를 지울수는 없다 //
s=t-next;
t-next = t-next-next;
free(s);
return 1;// return1 궁금합니다.
}
node *ordered_insert(int k)
{
node *p;
node *s;
node *r;
p=head;
s=p-next;
while(s-key=k && s!=tail)
{
p=p-next;
s=p-next;
}
r=(node*)malloc(sizeof(node));
r-key=k;
p-next=r;
r-next=s;
return r;// 궁금합니다~~
void main()
{
node *t;
init_list();
orderedinsert(10); //ordered_insert 함수호출
ordered_insert(5);
ordered_insert(8);
ordered_insert(3);
ordered_insert(1);
ordered_insert(7);
ordered_insert(8);delete_next(t);
print_list(head-next);t=find_node(3);
printf(\ndeleting next 3);
delete_next(t);
printf_list(head-next);
}항상 사이트에 도움을 구하고 있어 감사하게 생각합니다. 어려웟던 부분이엇는데 naruan 님께서
몇일전 어느분이 질문으로 올리신 링크드리스트에 대한 설명을
답글로 해주신거 보고 저도 따라서 공책에 그림그려가면서 이해 하고 있는중입니다.
c로배우는 알고리즘 (이재규 저)이 책사서 공부하고 있는데요 저한테는 어렵네요 ..
소스는 일부만 캡쳐했습니다. 제가 궁금한 부분은
ordered_insert()함수부분에 마지막에 returnr은 왜해주는지 궁금합니다.
return 은 반환하고 main에서 종료밖에 쓰지 않았는데
ordered_insert부분에서
return r; 리턴해준다는 의미 모르겠습니다.
delete_next함수 부분에서도 return 1 의 기능이 뭔가요.. 단순히 함수종료의 의미인가요?
-
눈
수다님 감사합니다.~~^^
-
우주
delete_next함수의 리턴은 단순히 성공여부를 판가름하기 위해 bool 대신 int를 쓴것 같군요.
0 이면 실패 1이면 성공...사용하는곳은 없네요.
orderred_insert()부분의 return은 추가된 노드를 반환하는건데 뭐 딱히 쓰이는곳은 없지만
코드 추가시 유용하게 쓸수 있으니 좋겠죠. 실패시 null을 리턴한다던지 해서
오류 체크도 가능하구요...
한마디로 현재 리턴값에 대한 처리가 없으니 무의미하지만 나중에 코드를 추가할때
유용하게
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |