成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

C++鏈表操作實際應用技巧分享

開發 后端
我們在這里將會以一段代碼示例來為大家詳細講解有關C++鏈表操作的實現方法,希望大家可以從中掌握到其中的應用技巧。

C++編程語言應用范圍廣泛,在開發人員眼中,它占據著非常重要的地位。在這里我們可以通過對C++鏈表操作的相關技巧,來充分了解一下這一語言的應用方式以及他的應用能給我們帶來哪些不同的感受。

C++鏈表操作代碼示例:

  1. // linklist.cpp : 定義控制臺應用程序的入口點。   
  2. #include "stdafx.h"   
  3. #include "malloc.h"   
  4. #include "stdlib.h"   
  5. #define NULL 0   
  6. #define LEN sizeof(struct student)   
  7. struct student   
  8. {   
  9. long num;   
  10. float score;   
  11. struct student* next;   
  12. };   
  13. int n;   
  14. struct student* creat()   
  15. {   
  16. struct student *head;   
  17. struct student *p1,*p2;   
  18. n=0;   
  19. p1=p2=(struct student*)malloc(LEN);   
  20. scanf("%ld",&p1->num);   
  21. scanf("%f",&p1->score);   
  22. head=NULL;   
  23. while (p1->num!=0)   
  24. {   
  25. n++;   
  26. if (n==1)   
  27. {   
  28. head=p1;   
  29. }   
  30. else   
  31. {   
  32. p2->next=p1;   
  33. }   
  34. p2=p1;   
  35. p1=(struct student*)malloc(LEN);   
  36. scanf("%ld",&p1->num);   
  37. if (p1->num==0)   
  38. break;   
  39. scanf("%f",&p1->score);   
  40. }   
  41. p2->next=NULL;   
  42. return (head);   
  43. };   
  44. void print(struct student *head)   
  45. {   
  46. struct student *p;   
  47. printf("\n New,These %d records are:\n",n);   
  48. p=head;   
  49. if (head!=NULL)   
  50. {   
  51. do   
  52. {   
  53. printf("%d %5.1f\n",p->num,p->score);   
  54. pp=p->next;   
  55. }while (p!=NULL);   
  56. }   
  57. }   
  58. struct student* insert(struct student *head,struct student *stud)   
  59. {   
  60. struct student *p0, *p1, *p2;   
  61. p1=head;   
  62. p0=stud;   
  63. if (head==NULL)   
  64. {   
  65. head=p0;   
  66. p0->next=NULL;//insert into head point   
  67. }   
  68. else   
  69. {   
  70. while ((p0->num>p1->num)&&(p1->next!=NULL))   
  71. {   
  72. p2=p1; //p2 is point to just p1 point to node;   
  73. p1p1=p1->next;   
  74. }   
  75. if (p0->num<=p1->num)   
  76. {   
  77. if (p1==head)   
  78. {   
  79. head=p0;//insert into before first node   
  80. }   
  81. else   
  82. {   
  83. p2->next=p0;//insert into after point p2   
  84. }   
  85. p0->next=p1;   
  86. }   
  87. else   
  88. {   
  89. p1->next=p0; //insert into after last point   
  90. p0->next=NULL;   
  91. }   
  92. }   
  93. n++;   
  94. return(head);   
  95. };   
  96. struct student* del(struct student *head,long num)   
  97. {   
  98. struct student *p1, *p2;   
  99. if (head==NULL)   
  100. {   
  101. printf("\n list Null!\n");   
  102. return (head);   
  103. }   
  104. p1=head;   
  105. while (num!=p1->num&&p1->next!=NULL)   
  106. //find num if equal p1->num   
  107. {   
  108. p2=p1;   
  109. p1p1=p1->next;   
  110. }   
  111. if (num==p1->num)   
  112. {   
  113. if (p1==head)   
  114. head=p1->next;//delete head node because num=head.num   
  115. else   
  116. p2->next=p1->next;//delete node. node is not head point   
  117. printf("delete:%ld\n",num);   
  118. n--;   
  119. }   
  120. else   
  121. {   
  122. printf("%ld not been found!\n",num);   
  123. }   
  124. return (head);   
  125. };   
  126. int _tmain(int argc, _TCHAR* argv[])   
  127. {   
  128. struct student *head,*end;   
  129. head=creat();   
  130. print(head);   
  131. struct student insertnode;   
  132. insertnode.num=3;   
  133. insertnode.score=900;   
  134. head=insert(head,&insertnode);   
  135. print(head);   
  136. head=del(head,3);   
  137. print(head);   
  138. return 0;   

C++鏈表操作的相關實現方法就為大家介紹到這里。

【編輯推薦】

  1. C++產生隨機數具體實現方法詳解
  2. C++打印地址信息實現方法介紹
  3. C++格式化字符串相關應用解析
  4. C++枚舉子相關類型解析
  5. C++枚舉類型用途及定義詳解
責任編輯:曹凱 來源: 博客園
相關推薦

2010-02-01 11:13:00

C++ Traits

2010-02-04 14:58:06

C++內存分配

2010-02-06 13:47:08

C++標準擴展

2010-03-01 13:06:49

WCF繼承

2010-02-05 13:44:06

C++ eof()函數

2010-02-06 16:16:01

C++冒泡排序

2010-02-05 18:04:21

C++剪切板

2011-07-13 16:36:11

C++

2010-02-03 15:35:00

C++輸入輸出漢字

2010-02-05 17:25:26

C++標識符命名規則

2010-03-03 16:25:41

Python字符串顯示

2010-03-01 17:52:03

WCF選擇綁定

2010-02-06 13:52:39

C++ profile

2010-02-04 11:15:28

C++模板限制

2010-02-06 10:24:48

C++二維數組初始化

2010-02-06 17:09:29

C++文件拷貝

2010-02-02 10:46:51

C++獲取文件大小

2010-02-04 11:38:43

C++獲取當前路徑

2009-08-25 17:02:20

C#串口操作

2009-08-19 11:28:41

C#操作Word
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区 | 国产黄色免费网站 | 最新伦理片 | 91玖玖 | 精品成人在线观看 | 欧美综合视频在线 | 成人av片在线观看 | 中文字幕免费 | 91视频进入 | www.亚洲视频.com | 中文字幕在线一区二区三区 | 国产一级片久久久 | 在线观看av网站永久 | aaa国产大片 | 美女天天干天天操 | 亚洲国产成人av好男人在线观看 | 免费一级做a爰片久久毛片潮喷 | 精品免费国产一区二区三区四区 | 精品久久久久久久久久久久久久 | 亚洲综合在线一区二区 | 奇米久久久| 国产精品久久久亚洲 | 91 在线 | 午夜精品视频在线观看 | 丝袜久久 | 91精品久久久久久综合五月天 | 九久久 | 午夜影院在线免费观看视频 | 天天干视频 | 在线一区二区三区 | 九色 在线 | 精品91久久 | 国产乡下妇女做爰 | 日韩在线播放网址 | www.亚洲精品| аⅴ资源新版在线天堂 | 日韩av一区二区在线 | 不卡一区| 亚洲国产精品一区二区www | 久久精品一级 | 欧美亚洲国产日韩 |