C語言實現單鏈表(帶頭結點)的基本操作(創建,頭插法,尾插法,刪除結點,打印鏈表)

http://blog.csdn.net/xiaofeige567/article/details/27484137

C語言實現單鏈表(帶頭結點)的基本操作(創建,頭插法,尾插法,刪除結點,打印鏈表)


[plain]?view plain?copy
  1. #include<stdio.h>??
  2. #include<stdlib.h>??
  3. ??
  4. typedef?struct?node??
  5. {??
  6. ????int?data;??
  7. ????struct?node?*next;??
  8. }Linklist;??
  9. ??
  10. Linklist?*create()?//創建鏈表,帶頭結點??
  11. {??
  12. ????Linklist?*head;??
  13. ????head=(Linklist?*)malloc(sizeof(Linklist));??
  14. ????head->next=NULL;??
  15. ????return?head;??????
  16. }??
  17. ??
  18. Linklist?*head_insert(Linklist?*head,int?value)?//頭插法,先插的元素排在后面??
  19. {??
  20. ????Linklist?*p,*t;??
  21. ????t=head;??
  22. ????p=(Linklist?*)malloc(sizeof(Linklist));??
  23. ????p->data=value;??
  24. ????p->next=t->next;??
  25. ????t->next=p;??
  26. ????return?head;??
  27. }??
  28. ??
  29. Linklist?*tail_insert(Linklist?*head,?int?value)?//尾插法??
  30. {??
  31. ????Linklist?*p,*t;??
  32. ????t=head;??
  33. ????p=(Linklist?*)malloc(sizeof(Linklist));??
  34. ????p->data=value;??
  35. ????while(t->next!=NULL)?//當鏈表不為空時t向后移動??
  36. ????t=t->next;??
  37. ??
  38. ????t->next=p;??
  39. ????p->next=NULL;??
  40. ????return?head;??????
  41. }??
  42. ??
  43. Linklist?*reverse(Linklist?*head)?//鏈表逆置??
  44. {??
  45. ????Linklist?*p,*t;??
  46. ????p=head->next;??
  47. ????t=p->next;??
  48. ????p->next=NULL;??
  49. ????while(t!=NULL)??
  50. ????{??
  51. ??????p=t->next;??
  52. ??????t->next=head->next;??
  53. ??????head->next=t;??
  54. ??????t=p;??
  55. ????}??
  56. ????return?head;??
  57. }??
  58. ??
  59. Linklist?*display(Linklist?*head)?//打印鏈表數據??
  60. {??
  61. ????Linklist?*p;??
  62. ????p=head->next;??
  63. ????if(p==NULL)??
  64. ????{??
  65. ????????printf("linklist?is?empty...\n");??
  66. ????????return?;??
  67. ????}??
  68. ????while(p!=NULL)??
  69. ????{??
  70. ??????printf("%5d",p->data);??
  71. ??????p=p->next;???
  72. ????}??
  73. ????printf("\n");?????
  74. ????return?head;??
  75. }??
  76. ??
  77. Linklist??*delete(Linklist?*head,int?value)?//刪除結點??
  78. {??
  79. ????Linklist?*p,*t;??
  80. ????p=head;??
  81. ????while(p->next!=NULL)??
  82. ????{??
  83. ????????if(p->next->data==value)??
  84. ????????{???
  85. ????????????t=p->next;??
  86. ????????????p->next=t->next;??
  87. ????????????free(t);??
  88. ????????????t=NULL;??
  89. ????????}??
  90. ????????else??
  91. ????????????p=p->next;?????????
  92. ????}??
  93. ????return?head;??
  94. }??
  95. ??
  96. Linklist?*sort(Linklist?*head)?//鏈表元素排序??
  97. {??
  98. ????int?i,j,t;??
  99. ????int?n=0;??
  100. ????Linklist?*p,*q;??
  101. ????p=head->next;??
  102. ?????
  103. ????while(p!=NULL)???
  104. ????{??
  105. ??????n++;??
  106. ??????p=p->next;??
  107. ??????}??
  108. ???????
  109. ???????for(i=0;i<n-1;i++)?//冒泡排序??
  110. ??????{??
  111. ?????????p=head->next;??
  112. ?????????q=p->next;??
  113. ??
  114. ????????????for(j=0;j<n-i-1;j++)??
  115. ??????????{???
  116. ??????????????if(p->data?>?q->data)??
  117. ?????????????{??
  118. ???????????????t=p->data;??
  119. ???????????????p->data=q->data;??
  120. ???????????????q->data=t;??
  121. ??????????????}???
  122. ??????????????
  123. ??????????????p=p->next;??
  124. ??????????????q=q->next;?????
  125. ??????????}??
  126. ??
  127. ???????}??
  128. ????return?head;??
  129. }??
  130. ??
  131. int?main()??
  132. {??
  133. ????Linklist?*head;??
  134. ????int?i,num;??
  135. ????head=create();??
  136. ??
  137. ????printf("head_insert:\n");??
  138. ????for(i=1;i<20;i=i+3)??
  139. ????head_insert(head,i);??
  140. ????display(head);??
  141. ??
  142. ????printf("linklist?reverse:\n");??
  143. ????reverse(head);??
  144. ????display(head);??
  145. ??
  146. ????printf("tail_insert:\n");??
  147. ????for(i=2;i<20;i=i+4)??
  148. ????tail_insert(head,i);??
  149. ????display(head);??
  150. ??????
  151. ????printf("delete?a?node:");??
  152. ????scanf("%d",&num);??
  153. ????delete(head,num);??
  154. ????display(head);??
  155. ??
  156. ????printf("linklist?sort:\n");??
  157. ????sort(head);??
  158. ????display(head);??
  159. ??
  160. ????return?0;??
  161. }??

Linux下的運行結果:


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/384272.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/384272.shtml
英文地址,請注明出處:http://en.pswp.cn/news/384272.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

靜態網頁與動態網頁區別

一、靜態web頁面&#xff1a;1、在靜態Web程序中&#xff0c;客戶端使用Web瀏覽器&#xff08;IE、FireFox等&#xff09;經過網絡(Network)連接到服務器上&#xff0c;使用HTTP協議發起一個請求&#xff08;Request&#xff09;&#xff0c;告訴服務器我現在需要得到哪個頁面&…

單向循環鏈表C語言實現

http://blog.csdn.net/morixinguan/article/details/51771633 我們都知道&#xff0c;單向鏈表最后指向為NULL&#xff0c;也就是為空&#xff0c;那單向循環鏈表就是不指向為NULL了&#xff0c;指向頭節點&#xff0c;所以下面這個程序運行結果就是&#xff0c;你將會看到遍歷…

web服務器原理

什么是web服務器&#xff1f; 在Mosaic瀏覽器&#xff08;通常被認為是第一個圖形化的web瀏覽器&#xff09;和超鏈接內容的初期&#xff0c;演變出了“web服務器”的新概念&#xff0c;它通過HTTP協議來提供靜態頁面內容和圖片服務。在那個時候&#xff0c;大多數內容都是靜態…

(C語言版)鏈表(三)——實現雙向鏈表創建、刪除、插入、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19760681 上午寫了下單向循環鏈表的程序&#xff0c;今天下午我把雙向鏈表的程序寫完了。其實雙向鏈表和單向鏈表也是有很多相似的地方的&#xff0c;聽名字可以猜到&#xff0c;每個節點都包含兩個指針&#xff0c;一個指針指…

競態條件

pause函數 調用該函數可以造成進程主動掛起&#xff0c;等待信號喚醒。調用該系統調用的進程將處于阻塞狀態(主動放棄cpu) 直到有信號遞達將其喚醒。 int pause(void); 返回值&#xff1a;-1 并設置errno為EINTR 返回值&#xff1a; ① 如果信號的默認處理動作是終止進程&#…

(C++版)鏈表(一)——實現單向鏈表創建、插入、刪除等相關操作

http://blog.csdn.net/fisherwan/article/details/25557545 前段時間用C語言實現了鏈表的相關操作&#xff0c;但是發現當時挺清楚的&#xff0c;過了一段時間又忘的差不多了&#xff0c;所以現在打算用C再實現一遍&#xff0c;由于初次用C實現&#xff0c;存在錯誤的地方還望大…

(C語言版)鏈表(二)——實現單向循環鏈表創建、插入、刪除、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19754585 昨天寫了單向鏈表的代碼&#xff0c;今天上午把單向循環鏈表的程序給敲完了。鏈表的相關操作一樣的&#xff0c;包含鏈表的創建、判斷鏈表是否為空、計算鏈表長度、向鏈表中插入節點、從鏈表中刪除節點、刪除整個鏈表…

計科院首頁靜態網頁

一.HTML代碼 <!DOCTYPE html><html><head><meta charset"UTF-8"><title>首頁</title> </head><body><div id"page"> <div id"page_head"> <div id"logo" aligncenter…

可重入函數

一個函數在被調用執行期間(尚未調用結束)&#xff0c;由于某種時序又被重復調用&#xff0c;稱之為“重入”。根據函數實現的方法可分為“可重入函數”和“不可重入函數”兩種。 注意事項 定義可重入函數&#xff0c;函數內不能含有全局變量及static變量&#xff0c;不能使用ma…

(C語言版)鏈表(四)——實現雙向循環鏈表創建、插入、刪除、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19801993 雙向循環鏈表是基于雙向鏈表的基礎上實現的&#xff0c;和雙向鏈表的操作差不多&#xff0c;唯一的區別就是它是個循環的鏈表&#xff0c;通過每個節點的兩個指針把它們扣在一起組成一個環狀。所以呢&#xff0c;每個…

SIGCHLD

SIGCHLD的產生條件 子進程終止時 子進程接收到SIGSTOP信號停止時 子進程處在停止態&#xff0c;接受到SIGCONT后喚醒時 借助SIGCHLD信號回收子進程 子進程結束運行&#xff0c;其父進程會收到SIGCHLD信號。該信號的默認處理動作是忽略。可以捕捉該信號&#xff0c;在捕捉函數中…

(C語言版)鏈表(一)——實現單向鏈表創建、插入、刪除等簡單操作(包含個人理解說明及注釋,新手跟著寫代碼)

http://blog.csdn.net/fisherwan/article/details/19701027 我學習了幾天數據結構&#xff0c;今天下午自己寫了一個單向鏈表的程序。我也是新手&#xff0c;所以剛開始學習數據結構的菜鳥們&#xff08;有大牛們能屈尊看一看&#xff0c;也是我的榮幸&#xff09;可以和我一起…

中斷系統調用

中斷系統調用 系統調用可分為兩類&#xff1a;慢速系統調用和其他系統調用。 慢速系統調用&#xff1a;可能會使進程永遠阻塞的一類。如果在阻塞期間收到一個信號&#xff0c;該系統調用就被中斷,不再繼續執行(早期)&#xff1b;也可以設定系統調用是否重啟。如&#xff0c;rea…

(C++版)鏈表(二)——實現單項循環鏈表創建、插入、刪除等操作

http://blog.csdn.net/fisherwan/article/details/25561857 鏈表&#xff08;二&#xff09;單向循環鏈表的實現&#xff0c;下面實現代碼&#xff1a; [cpp] view plaincopy <span style"font-size:18px;" deep"5">#include <iostream> #in…

會話

創建會話 創建一個會話需要注意以下6點注意事項&#xff1a; 調用進程不能是進程組組長&#xff0c;該進程變成新會話首進程(session header)該進程成為一個新進程組的組長進程。需有root權限(ubuntu不需要)新會話丟棄原有的控制終端&#xff0c;該會話沒有控制終端該調用進程是…

守護進程

守護進程 Daemon(精靈)進程&#xff0c;是Linux中的后臺服務進程&#xff0c;通常獨立于控制終端并且周期性地執行某種任務或等待處理某些發生的事件。一般采用以d結尾的名字。 Linux后臺的一些系統服務進程&#xff0c;沒有控制終端&#xff0c;不能直接和用戶交互。不受用戶登…

(C++版)鏈表(三)——實現雙向鏈表的創建、插入、刪除等簡單操作

http://blog.csdn.net/fisherwan/article/details/25649073 鏈表&#xff08;三&#xff09;實現雙向鏈表操作&#xff0c;代碼如下&#xff1a; [cpp] view plaincopy <span style"font-size:18px;" deep"5">#include <iostream> #include …

(C++版)鏈表(四)——實現雙向循環鏈表創建、插入、刪除等簡單操作

http://blog.csdn.net/fisherwan/article/details/25649271 鏈表&#xff08;四&#xff09;實現雙向循環鏈表簡單操作&#xff0c;代碼如下&#xff1a; [cpp] view plaincopy <span style"font-size:18px;" deep"5">#include <iostream> #…

java web開發環境搭建

1.安裝并配置JDK環境&#xff08;1&#xff09;安裝過程省略&#xff08;建議安裝在自己指定的統一目錄下&#xff0c;方便后期查找&#xff09;。 &#xff08;2&#xff09;配置環境變量 JAVA_HOME: C:\Java\jdk\jdk1.7.0_45 &#xff08;jdk安裝目錄路徑&#xff09; Path:…

java script簡介

一.JavaScript介紹&#xff08;摘抄于百度百科&#xff09; JavaScript一種直譯式腳本語言&#xff0c;是一種動態類型、弱類型、基于原型的語言&#xff0c;內置支持類型。它的解釋器被稱為JavaScript引擎&#xff0c;為瀏覽器的一部分&#xff0c;廣泛用于客戶端的腳本語言&a…