연결리스트 질문입니다!
여신
질문 제목 : 연결리스트 질문입니다!질문 요약 :ListNode *merge(ListNode *aHead, ListNode *bHead ) 함수가 문제입니다.오름차순으로 정렬된 a와b. 두개의 연결리스트를 a1과 b1을비교해서작은 값을 c1에 넣고, 그다음에 또 비교해서 c2에 넣는 함수입니다. 즉, 두 개의 연결리스트를 비교해서 C라는 새로운 연결리스트에 오름차순으로 정렬하는 것입니다. merge 함수에서 오류가 나지는 않지만 원하던 답이 나오지 않습니다. 고수님들 머가 문제인지 알려주세요ㅜㅠ질문 내용 :
#include stdio.h
#include stdlib.h
typedef struct ListNode {
int data;
struct ListNode *link;
} ListNode;
void insert_node(ListNode **phead, ListNode *p, ListNode *new_node)
{
if(*phead==NULL){
new_node-link=NULL;
*phead=new_node;
}
else if(p==NULL){
new_node-link=*phead;
*phead=new_node;
}
else{
new_node-link=p-link;
p-link=new_node;
}
}
ListNode *create_node(int data, ListNode *link)
{
ListNode *new_node;
new_node=(ListNode *)malloc(sizeof(ListNode));
new_node-data=data;
new_node-link=link;
return(new_node);
}
void display(ListNode *head)
{
ListNode *p=head;
while(p!=NULL){
printf(%d-, p-data);
p=p-link;
}
printf(\n);
}
ListNode *merge(ListNode *aHead, ListNode *bHead )// ----- 요기
{
ListNode *c=NULL;
ListNode *p1, *p2;
p1=aHead;
p2=bHead;
while(p1 != NULL || p2 != NULL){
if(p1 != NULL){
if(aHead-data bHead-data)
insert_node(&c, NULL, create_node(p1-data, NULL));
p1=p1-link;
}
if(p2 != NULL){
if(aHead-data bHead-data)
insert_node(&c, NULL, create_node(p2-data, NULL));
p2=p2-link;
}
}
return c;
}
void main()
{
ListNode *A=NULL, *B=NULL;
ListNode *C=NULL;
insert_node(&A, NULL, create_node(1, NULL));
insert_node(&A, NULL, create_node(3, NULL));
display(A);
insert_node(&B, NULL, create_node(2, NULL));
insert_node(&B, NULL, create_node(4, NULL));
insert_node(&B, NULL, create_node(6, NULL));
display(B);
C=alternate(A, B);
display(C);
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |
2693328 | C언어를이용해서 .txt파일 외에 다른 확장자 파일 삭제가 가능한지.. (2) | 대나무 | 2025-05-01 |
2693299 | 파일입출력 바이너리파일 | 독특한 | 2025-04-30 |
2693273 | 오류 (1) | 귀1여운렩 | 2025-04-30 |
2693080 | visual studio 2008 express edition 등록키 말인데요 | 얀별 | 2025-04-28 |
2693053 | 배열, 구조체 관련 프로그래밍 질문드립니다. | 싸리 | 2025-04-28 |
2693025 | 프로그램을 짜봤는데요 ㅠㅠ | 상처입은마음 | 2025-04-28 |
2693001 | 워닝문제, 세그멘트결함문제 (1) | 월식 | 2025-04-28 |