링크드 리스트 중간삽입 질문이요!
핫블루
질문 제목 :링크드 리스트 중간삽입 질문이요!질문 요약 :add()란 함수로 제일처음삽입,끝삽입,중간삽입을 하는데
데이터를 중간과 끝이 받아지질 않네요..
질문 내용 :
#includestdio.h#includeconio.h#includestdlib.h
void select(void); //입력void modify(void); //수정void print(void); //출력void del(void);void add();int sel;
struct emp { int num; int age; char name[20]; char add[20]; struct emp *next;} *ptr,*head, *tail, *x, *prev;
main(void){ head=tail=null; while(1) { printf(1.항목 추가\n); printf(2.항목 수정\n); printf(3.항목 삭제\n); printf(4.항목 출력\n); printf(5.중간삽입\n); printf(6.종료\n); printf(작업 선택 : ); scanf(%d,&sel); fflush(stdin);
switch(sel) { case 1: select(); break; case 2: modify(); break; case 3: del(); break; case 4: print(); break; case 5: add(); break; case 6: exit(1); }//switch }//while getch();}//main//////addvoid add(){ //int a=0; while(1) { ptr=(struct emp*)malloc(sizeof(struct emp)); //메모리할당 if(ptr==null) { printf(heap영역 할당오류 \n); exit(1); } //자료입력 printf(학번 (입력종료:-1) : ); scanf(%d,&ptr-num); fflush(stdin); if(ptr-num == -1) { break; } printf(이름 : ); gets(ptr-name); printf(나이 : ); scanf(%d,&ptr-age); fflush(stdin); printf(주소 : ); gets(ptr-add); ptr-next=null; //주소연결 if(head==null) { head=ptr; }else { //추가로연결 x=head; while(x) { if(x-num == ptr-num) { printf(중복입니다\n); free(ptr); }else if(x-num ptr-num) { prev=x; x=x-next; }else { break; } }//while if(x==head) { //첫번째 삽입 head=ptr; ptr-next=x; }else if(x=null) { //마지막삽입 ptr=tail-next; }else { //가운데 삽입 x-next=ptr; ptr-next=tail; } }//추가로연결 else }//맨위 while}//main