단일 연결 리스트 질문입니다..
난길
질문 제목 : 단일 연결 리스크 구현입니다.코드는 간단히 1: 입력 2: 삭제 3: 출력 4 : 종료입니다.
지금 1입력부분때문에 pdata nodealloc(int data)
pdata makenode(pdata head,int todata)
void inputnode(pdata *head,int data)
3개의 함수를 사용중인대 1개로 줄일라면 어떻게 해야하나요??줄이면 계속 주소참조로 에로발생합니다.질문 내용 : #include stdafx.h
#include string.h
#include stdlib.h
typedef struct _node {
int input;
struct _node *link;
}data,*pdata; //구조체 선언
void remove(pdata *head)
{
pdata p=*head;
pdata pre;
int deletecount;
printf(지우고자 하는 수는 ? : );
scanf_s(%d,&deletecount);
while(p && p-input != deletecount)
{
pre = p;
p=p-link;
}
if(p-link == null)
printf(찾는 data 없다 \n);
else if(*head == p)
{
*head = p-link;
free(p);
}
else
{
pre-link = p-link;
free(p);
}
}pdata nodealloc(int data)
{
pdata p = (pdata)malloc(sizeof(data));
p-input = data;
p-link = null;
return p;
}
pdata makenode(pdata head,int todata)
{
pdata n,p;
p=head;
n=nodealloc(todata);
/*n=(pdata)malloc(sizeof(data));
n-input = todata;
n-link = null;*/
if(head==null)
return n;
while(p-link)
p=p-link;
p-link = n;
return head;
}
void inputnode(pdata *head,int data)
{
*head=makenode(*head,data);
}
void printnode(pdata head)
{
pdata p=head;
int i;
printf(\n\n);
for(i=1;p;p=p-link,i++)
{
printf(%d 번째 요소 %d\n,i,p-input);
}
printf(\n\n);
}
int _tmain(int argc, _tchar* argv[])
{
int inputcount=0;
int count=0;
pdata head=null;
while(1)
{
printf(1. 정수입력 :\n);
printf(2. 정수 삭제 :\n);
printf(3. 정수 출력 :\n);
printf(4.종료 );
scanf_s(%d,&inputcount);
switch(inputcount)
{
case 1:
printf(정수 입력 : );
scanf_s(%d,&count);
inputnode(&head,count);
break;
case 2:
remove(&head);
break;
case 3:
printnode(head);
break;
case 4:
printf(종료합니다 \n);
break;
}
if(inputcount == 4)
break;
}
return 0;
}
-
앨런 2023-10-08
예 비쥬얼 2008인대 저렇게 나오더라고요 //
-
말근 2023-10-08
_tmain이라고 적어도 에러 안뜨나요??