首頁考試吧論壇Exam8視線考試商城網(wǎng)絡(luò)課程模擬考試考友錄實用文檔求職招聘論文下載
2013中考
法律碩士
2013高考
MBA考試
2013考研
MPA考試
在職研
中科院
考研培訓(xùn) 自學(xué)考試 成人高考
四 六 級
GRE考試
攻碩英語
零起點日語
職稱英語
口譯筆譯
申碩英語
零起點韓語
商務(wù)英語
日語等級
GMAT考試
公共英語
職稱日語
新概念英語
專四專八
博思考試
零起點英語
托?荚
托業(yè)考試
零起點法語
雅思考試
成人英語三級
零起點德語
等級考試
華為認證
水平考試
Java認證
職稱計算機 微軟認證 思科認證 Oracle認證 Linux認證
公 務(wù) 員
導(dǎo)游考試
物 流 師
出版資格
單 證 員
報 關(guān) 員
外 銷 員
價格鑒證
網(wǎng)絡(luò)編輯
駕 駛 員
報檢員
法律顧問
管理咨詢
企業(yè)培訓(xùn)
社會工作者
銀行從業(yè)
教師資格
營養(yǎng)師
保險從業(yè)
普 通 話
證券從業(yè)
跟 單 員
秘書資格
電子商務(wù)
期貨考試
國際商務(wù)
心理咨詢
營 銷 師
司法考試
國際貨運代理人
人力資源管理師
廣告師職業(yè)水平
衛(wèi)生資格 執(zhí)業(yè)醫(yī)師 執(zhí)業(yè)藥師 執(zhí)業(yè)護士
會計從業(yè)資格
基金從業(yè)資格
統(tǒng)計從業(yè)資格
經(jīng)濟師
精算師
統(tǒng)計師
會計職稱
法律顧問
ACCA考試
注冊會計師
資產(chǎn)評估師
審計師考試
高級會計師
注冊稅務(wù)師
國際內(nèi)審師
理財規(guī)劃師
美國注冊會計師
一級建造師
安全工程師
設(shè)備監(jiān)理師
公路監(jiān)理師
公路造價師
二級建造師
招標師考試
物業(yè)管理師
電氣工程師
建筑師考試
造價工程師
注冊測繪師
質(zhì)量工程師
巖土工程師
造價員考試
注冊計量師
環(huán)保工程師
化工工程師
咨詢工程師
結(jié)構(gòu)工程師
城市規(guī)劃師
材料員考試
監(jiān)理工程師
房地產(chǎn)估價
土地估價師
安全評價師
房地產(chǎn)經(jīng)紀人
投資項目管理師
環(huán)境影響評價師
土地登記代理人
繽紛校園 實用文檔 英語學(xué)習(xí) 作文大全 求職招聘 論文下載 訪談|游戲
軟件水平考試
軟件水平考試資訊
軟件水平考試試題
軟件水平考試專項輔導(dǎo)
軟件水平考試交流互動
軟件水平考試交流互動
您現(xiàn)在的位置: 考試吧 > 軟件水平考試 > 復(fù)習(xí)資料 > 程序員資料 > 正文

C語言初學(xué)者入門知識之結(jié)構(gòu)體3

  1. 原表是空表,只需使head指向被插結(jié)點即可。

  2. 被插結(jié)點值最小,應(yīng)插入第一結(jié)點之前。這種情況下使head指向被插結(jié)點,被插結(jié)點的指針域指向原來的第一結(jié)點則可。即:

  pi->next=pb;

  head=pi;

  3. 在其它位置插入。這種情況下,使插入位置的前一結(jié)點的指針域指向被插結(jié)點,使被插結(jié)點的指針域指向插入位置的后一結(jié)點。即為:pi->next=pb;pf->next=pi;

  4. 在表末插入。這種情況下使原表末結(jié)點指針域指向被插結(jié)點,被插結(jié)點指針域置為NULL。

  即:

  pb->next=pi;

  pi->next=NULL; TYPE * insert(TYPE * head,TYPE *pi)

  {

  TYPE *pf,*pb;

  pb=head;

  if(head==NULL) /*空表插入*/

  (head=pi;

  pi->next=NULL;}

  else

  {

  while((pi->num>pb->num)&&(pb->next!=NULL))

  {

  pf=pb;

  pb=pb->next;

  }/*找插入位置*/

  if(pi->num<=pb->num)

  {

  if(head==pb)head=pi;/*在第一結(jié)點之前插入*/

  else pf->next=pi;/*在其它位置插入*/

  pi->next=pb; }

  else

  {

  pb->next=pi;

  pi->next=NULL;

  } /*在表末插入*/

  }

  return head;

  }

  本函數(shù)有兩個形參均為指針變量,head指向鏈表,pi 指向被插結(jié)點。函數(shù)中首先判斷鏈表是否為空,為空則使head指向被插結(jié)點。表若不空,則用while語句循環(huán)查找插入位置。找到之后再判斷是否在第一結(jié)點之前插入,若是則使head 指向被插結(jié)點被插結(jié)點指針域指向原第一結(jié)點,否則在其它位置插入, 若插入的結(jié)點大于表中所有結(jié)點,則在表末插入。本函數(shù)返回一個指針,是鏈表的頭指針。當插入的位置在第一個結(jié)點之前時, 插入的新結(jié)點成為鏈表的第一個結(jié)點,因此head的值也有了改變, 故需要把這個指針返回主調(diào)函數(shù)。

  [例7.14]將以上建立鏈表,刪除結(jié)點,插入結(jié)點的函數(shù)組織在一起,再建一個輸出全部結(jié)點的函數(shù),然后用main函數(shù)調(diào)用它們。

  #define NULL 0

  #define TYPE struct stu

  #define LEN sizeof(struct stu)

  struct stu

  {

  int num;

  int age;

  struct stu *next;

  };

  TYPE * creat(int n)

  {

  struct stu *head,*pf,*pb;

  int i;

  for(i=0;i

  {

  pb=(TYPE *)malloc(LEN);

  printf("input Number and Age\n");

  scanf("%d%d",&pb->num,&pb->age);

  if(i==0)

  pf=head=pb;

  else pf->next=pb;

  pb->next=NULL;

  pf=pb;

  }

  return(head);

  }

  TYPE * delete(TYPE * head,int num)

  {

  TYPE *pf,*pb;

  if(head==NULL)

  {

  printf("\nempty list!\n");

  goto end;

  }

  pb=head;

  while (pb->num!=num && pb->next!=NULL)

  {

  pf=pb;pb=pb->next;

  }

  if(pb->num==num)

  {

  if(pb==head) head=pb->next;

  else pf->next=pb->next;

  printf("The node is deleted\n");

  }

  else

  free(pb);

  printf("The node not been found!\n");

  end:

  return head;

  }

  TYPE * insert(TYPE * head,TYPE * pi)

  {

  TYPE *pb ,*pf;

  pb=head;

  if(head==NULL)

  {

  head=pi;

  pi->next=NULL;

  }

  else

  {

  while((pi->num>pb->num)&&(pb->next!=NULL))

  {

  pf=pb;

  pb=pb->next;

  }

  if(pi->num<=pb->num)

  {

  if(head==pb) head=pi;

  else pf->next=pi;

  pi->next=pb;

  }

  else

  {

  pb->next=pi;

  pi->next=NULL;

  }

  }

  return head;

  }

  void print(TYPE * head)

  {

  printf("Number\t\tAge\n");

  while(head!=NULL)

  {

  printf("%d\t\t%d\n",head->num,head->age);

  head=head->next;

  }

  }

  main()

  {

  TYPE * head,*pnum;

  int n,num;

  printf("input number of node: ");

  scanf("%d",&n);

  head=creat(n);

  print(head);

  printf("Input the deleted number: ");

  scanf("%d",&num);

  head=delete(head,num);

  print(head);

  printf("Input the inserted number and age: ");

  pnum=(TYPE *)malloc(LEN);

  scanf("%d%d",&pnum->num,&pnum->age);

  head=insert(head,pnum);

  print(head);

  }

上一頁  1 2 3 4 5 6 下一頁

  相關(guān)推薦:

  2012年軟考系統(tǒng)分析師考試60天完美復(fù)習(xí)計劃

  2012年軟件水平考試網(wǎng)絡(luò)工程師章節(jié)筆記講義匯總

  2012年上半年軟件水平考試成績查詢匯總

文章搜索
軟件水平考試欄目導(dǎo)航
版權(quán)聲明:如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請注明出處。