程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> 結構體鏈表-c語言鏈表,輸入輸出正確但是刪除操作報錯

結構體鏈表-c語言鏈表,輸入輸出正確但是刪除操作報錯

編輯:編程解疑
c語言鏈表,輸入輸出正確但是刪除操作報錯

#include
#include
#define len sizeof(struct student)

struct student
{int num;
float score;
struct student *next;
};

struct student *creat(void) // 建立
{struct student *p1,*p2,*head;
int n=0;
p1=p2=(struct student *)malloc(len);
scanf("%d %f",&p1->num,&p1->score);
head=NULL;
while(p1->num!=0)
{n=n+1;
if(n==1)
head=p1;
else
p2->next=p1;
p2=p1;
p1=(struct student *)malloc(len);
scanf("%d %f",&p1->num,&p1->score);

}
p2->next=NULL;
return(head);
}

void print(struct student *head) // 輸出
{struct student *p;
p=head;
if(head!=NULL)
for(;p!=NULL;)
{printf("%d %f\n",p->num,p->score);
p=p->next;

}}

struct student *del(struct student *head,int num) // 刪除
{struct student *p1,*p2=NULL;

if(head=NULL)
printf("空鏈表,無法操作");
else
{p1=head;
while((num!=p1->num)&&(p1->next!=NULL))
{p2=p1;
p1=p1->next;
}

if(num==p1->num)
{if(p1==head)
head=p1->next;
else
p2->next=p1->next;
free(p1);
printf("此鏈表已刪除");
}
else
printf("無此數據,錯誤");
}
return head;

}

main()
{struct student *head,*p;
int num;
head=creat();
printf("輸入要查找的數據並刪除:\n");
scanf("%d",&num);
p=del(head,num);
printf("刪除後數據為:");
print(p);

}

最佳回答:


崩潰的時候在彈出的對話框按相應按鈕進入調試,按Alt+7鍵查看Call Stack即“調用堆棧”裡面從上到下列出的對應從裡層到外層的函數調用歷史。雙擊某一行可將光標定位到此次調用的源代碼或匯編指令處,看不懂時雙擊下一行,直到能看懂為止。

代碼功能歸根結底不是別人幫自己看或講解或注釋出來的;而是被自己靜下心來花足夠長的時間和精力親自動手單步或設斷點或對執行到某步獲得的中間結果顯示或寫到日志文件中一步一步分析出來的。
提醒:再牛×的老師也無法代替學生自己領悟和上廁所!
單步調試和設斷點調試(VS IDE中編譯連接通過以後,按F10或F11鍵單步執行,按Shift+F11退出當前函數;在某行按F9設斷點後按F5執行停在該斷點處。)是程序員必須掌握的技能之一。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved