단순연결리스트 삽입부분좀 봐주세요
훌걸이
질문 제목 : 단순연결리스트 삽입부분..질문 요약 :
#include stdio.h
#include stdlib.h
struct node
{
int data;
struct node* link;
};
void turninput(struct node*);
int count=0;
int main()
{
struct node* l=null;
struct node* temp;
int button,number,i;
do
{
printf((1)순차적입력 (2)선택적입력\n);
scanf(%d,&button);
switch(button)
{
case 1:
turninput(l);
break;
}while(button!=3);printf(이제 단순연결리스트를 출력하겠습니다\n); //버튼 3 입력시 빠져나오면서 출력시작
temp=l;
while(temp!=null)
{
printf(%d ,temp-data);
temp=temp-link;
}
return 0;
}void turninput(struct node* l)//순차적삽입(0이 들어올때까지 계속입력받음)함수정의
{
struct node* newnode;
struct node* temp;
while(1)
if(l==null) //첫번째 원소 넣을때
{
printf(%d번째 원소를 입력합니다\n,count+1);
newnode=(struct node*)malloc(sizeof(struct node));
printf(원소를 입력하세요:);
scanf(%d,&newnode-data);
if(newnode-data==0) //0이면 빠져나감
break;
l=newnode;
l-link=null;
count++;
}
else //2번째 이상의 원소 넣을때
{
printf(%d번째 원소를 입력합니다\n,count+1);
temp=l;
while(temp-link!=null)
temp=temp-link;
newnode=(struct node*)malloc(sizeof(struct node));
printf(원소를 입력하세요:);
scanf(%d,&newnode-data);
if(newnode-data==0) //0이면 빠져나감
break;
newnode-link=null;
temp-link=newnode;
count++;
}
}질문 내용 :
l이 헤더고 맨 처음에 실행시공백리스트일때 순차적으로 삽입하는건데
함수를 안만들어서 했을땐 올바르게 되는데
함수를 만들어서 하니까 함수안에서는 잘 연결되고main으로 돌아가니까l이 초기화 되버리는데 왜이런거죠???
리턴값으로 l을 넘기면 또 올바르게 되는데 그러면 struct node*를 넘긴의미가 없잖아요...
모르겟어요ㅠㅠ
도와주세요 잘못한게 없는것같은데 너무 답답하네요ㅠ
-
흰가람 2024-04-09
와!!오호 감사해요ㅠㅠ와 진짜 계속고민햇는대다행이네요ㅠㅠㅠ
-
또야 2024-04-09
TurnInput() 안에 있는 input parameter 를 모두 뺴고 하니까 잘 되네요.
1. struct node * L=NULL 을 전역으로 설정
2. void TurnInput() ;으로 변경 - L이 재정의 되면서 NULL로 바뀌는것 같네요 -
꽃겨울 2024-04-09
흠 그래도안되요ㅠㅠ
-
머슴밥 2024-04-09
L이 초기화 되는건 main 안에서 struct Node * L = NULL 이라고 하셔서 그런듯 하네요.
전역으로 설정하시면 될거같아요