日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

單鏈表學(xué)習(xí)的超詳細(xì)說(shuō)明(二)

電子設(shè)計(jì) ? 來(lái)源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-24 17:33 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

昨天跟大家分享了單鏈表的一些基本用法,今天接著繼續(xù)和大家分享單鏈表的用法,今天分享完,單鏈表的操作就暫告一段落了,后面接著分享雙鏈表的學(xué)習(xí)和實(shí)戰(zhàn)!

一、單鏈表的遍歷

1、什么叫遍歷?

遍歷就是把單鏈表中的各個(gè)節(jié)點(diǎn)挨個(gè)拿出來(lái),就叫遍歷。

2、如何來(lái)遍歷單鏈表?

從頭指針+頭節(jié)點(diǎn)開(kāi)始,順著鏈表掛接指針依次訪問(wèn)鏈表的各個(gè)節(jié)點(diǎn),取出這個(gè)節(jié)點(diǎn)的數(shù)據(jù),然后再往下一個(gè)節(jié)點(diǎn),直到最后一個(gè)節(jié)點(diǎn),結(jié)束訪問(wèn)。

3、注意事項(xiàng):

一是不能遺漏元素,二是不能重復(fù)、追求效率

4、實(shí)戰(zhàn)代碼演示:

1 #include <stdio.h>

2 #include <strings.h>

3 #include <stdlib.h>

4// 構(gòu)建一個(gè)鏈表的節(jié)點(diǎn)

5struct node

6 {

7 int data; // 有效數(shù)據(jù)

8 struct node *pNext; // 指向下一個(gè)節(jié)點(diǎn)的指針

9 };

10 // 作用:創(chuàng)建一個(gè)鏈表節(jié)點(diǎn)

11 // 返回值:指針,指針指向我們本函數(shù)新創(chuàng)建的一個(gè)節(jié)點(diǎn)的首地址

12 struct node * create_node(int data)

13 {

14 struct node *p = (struct node *)malloc(sizeof(struct node));

15 if (NULL == p)

16 {

17 printf("malloc error.n");

18 return NULL;

19 }

20 // 清理申請(qǐng)到的堆內(nèi)存

21 bzero(p, sizeof(struct node));

22 // 填充節(jié)點(diǎn)

23 p->data = data;

24 p->pNext = NULL;

25 return p;

26}

27// 計(jì)算添加了新的節(jié)點(diǎn)后總共有多少個(gè)節(jié)點(diǎn),然后把這個(gè)數(shù)寫(xiě)進(jìn)頭節(jié)點(diǎn)中。

28void insert_tail(struct node *pH, struct node *new)

29{

30 int cnt = 0;

31 // 分兩步來(lái)完成插入

32 // 第一步,先找到鏈表中最后一個(gè)節(jié)點(diǎn)

33 struct node *p = pH;

34 while (NULL ?。?p->pNext)

35 {

36 p = p->pNext; // 往后走一個(gè)節(jié)點(diǎn)

37 cnt++;

38 }

39 // 第二步,將新節(jié)點(diǎn)插入到最后一個(gè)節(jié)點(diǎn)尾部

40 p->pNext = new;

41 pH->data = cnt + 1;

42 }

43 void insert_h(yuǎn)ead(struct node *pH, struct node *new)

44 {

45 // 第1步: 新節(jié)點(diǎn)的next指向原來(lái)的第一個(gè)節(jié)點(diǎn)

46 new->pNext = pH->pNext;

47 // 第2步: 頭節(jié)點(diǎn)的next指向新節(jié)點(diǎn)的地址

48 pH->pNext = new;

49 // 第3步: 頭節(jié)點(diǎn)中的計(jì)數(shù)要加1

50 pH->data += 1;

51 }

52 // 遍歷單鏈表,pH為指向單鏈表的頭指針,遍歷的節(jié)點(diǎn)數(shù)據(jù)打印出來(lái)

53 void bianli(struct node*pH)

54 {

55 //pH->data // 頭節(jié)點(diǎn)數(shù)據(jù),不是鏈表的常規(guī)數(shù)據(jù),不要算進(jìn)去了

56 //struct node *p = pH; // 錯(cuò)誤,因?yàn)轭^指針后面是頭節(jié)點(diǎn)

57 struct node *p = pH->pNext; // p直接走到第一個(gè)節(jié)點(diǎn)

58 printf("-----------開(kāi)始遍歷-----------n");

59 // 是不是最后一個(gè)節(jié)點(diǎn)

60 while (NULL ?。?p->pNext)

61 {

62 printf("node data: %d.n", p->data);

63 p = p->pNext;

64 // 走到下一個(gè)節(jié)點(diǎn),也就是循環(huán)增量

65 }

66 printf("node data: %d.n", p->data);

67 printf("-------------完了-------------n");

68 }

69int main(void)

70{

71 // 定義頭指針

72 //struct node *pHeader = NULL;

73 // 這樣直接insert_tail會(huì)段錯(cuò)誤。

74 struct node *pHeader = create_node(0);

75 insert_h(yuǎn)ead(pHeader, create_node(11));

76 insert_h(yuǎn)ead(pHeader, create_node(12));

77 insert_h(yuǎn)ead(pHeader, create_node(13));

78 // 訪問(wèn)鏈表頭節(jié)點(diǎn)的有效數(shù)據(jù)

79 printf("beader node data: %d.n", pHeader->data);

80 bianli(pHeader);

81 return 0;

82 }

編譯結(jié)果;

1root@ubuntu-virtual-machine:/mnt/hgfs/day# gcc flie1.c

2root@ubuntu-virtual-machine:/mnt/hgfs/day# ./a.out

3beader node data: 3.

4----------開(kāi)始遍歷-----------

5node data: 13.

6node data: 12.

7node data: 11.

8 -------------完了-------------

二、單鏈表的刪除

1、如何找到要?jiǎng)h除的節(jié)點(diǎn)?

通過(guò)遍歷來(lái)查找節(jié)點(diǎn)。從頭指針+頭節(jié)點(diǎn)開(kāi)始,順著鏈表依次將各個(gè)節(jié)點(diǎn)拿出來(lái),按照一定的方法比對(duì),找到我們要?jiǎng)h除的那個(gè)節(jié)點(diǎn)。

2、如何來(lái)刪除一個(gè)節(jié)點(diǎn)?

(1)待刪除的節(jié)點(diǎn)不是尾節(jié)點(diǎn)的情況:首先把待刪除的節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)的pNext指針指向待刪除的節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn)的首地址(這樣就把這個(gè)節(jié)點(diǎn)從鏈表中摘出來(lái)了),然后再將這個(gè)摘出來(lái)的節(jié)點(diǎn)free掉接口。

(2)待刪除的節(jié)點(diǎn)是尾節(jié)點(diǎn)的情況:首先把待刪除的尾節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)的pNext指針指向null(這時(shí)候就相當(dāng)于原來(lái)尾節(jié)點(diǎn)前面的一個(gè)節(jié)點(diǎn)變成了新的尾節(jié)點(diǎn)),然后將摘出來(lái)的節(jié)點(diǎn)free掉。

3、實(shí)戰(zhàn)代碼演示:

1 #include <stdio.h>

2 #include <strings.h>

3 #include <stdlib.h>

4// 構(gòu)建一個(gè)鏈表的節(jié)點(diǎn)

5struct node

6 {

7 int data; // 有效數(shù)據(jù)

8 struct node *pNext;

9 // 指向下一個(gè)節(jié)點(diǎn)的指針

10 };

11 // 作用:創(chuàng)建一個(gè)鏈表節(jié)點(diǎn)

12 // 返回值:指針,指針指向我們本函數(shù)新創(chuàng)建的一個(gè)節(jié)點(diǎn)的首地址

13 struct node * create_node(int data)

14 {

15 struct node *p = (struct node *)malloc(sizeof(struct node));

16 if (NULL == p)

17 {

18 printf("malloc error.n");

19 return NULL;

20 }

21 // 清理申請(qǐng)到的堆內(nèi)存

22 bzero(p, sizeof(struct node));

23 // 填充節(jié)點(diǎn)

24 p->data = data;

25 p->pNext = NULL;

26 return p;

27}

28// 計(jì)算添加了新的節(jié)點(diǎn)后總共有多少個(gè)節(jié)點(diǎn),然后把這個(gè)數(shù)寫(xiě)進(jìn)頭節(jié)點(diǎn)中。

29void insert_tail(struct node *pH, struct node *new)

30{

31 int cnt = 0;

32 // 分兩步來(lái)完成插入

33 // 第一步,先找到鏈表中最后一個(gè)節(jié)點(diǎn)

34 struct node *p = pH;

35 while (NULL ?。?p->pNext)

36 {

37 p = p->pNext; // 往后走一個(gè)節(jié)點(diǎn)

38 cnt++;

39 }

40 // 第二步,將新節(jié)點(diǎn)插入到最后一個(gè)節(jié)點(diǎn)尾部

41 p->pNext = new;

42 pH->data = cnt + 1;

43 }

44 void insert_h(yuǎn)ead(struct node *pH, struct node *new)

45 {

46 // 第1步: 新節(jié)點(diǎn)的next指向原來(lái)的第一個(gè)節(jié)點(diǎn)

47 new->pNext = pH->pNext;

48 // 第2步: 頭節(jié)點(diǎn)的next指向新節(jié)點(diǎn)的地址

49 pH->pNext = new;

50 // 第3步: 頭節(jié)點(diǎn)中的計(jì)數(shù)要加1

51 pH->data += 1;

52 }

53 // 遍歷單鏈表,pH為指向單鏈表的頭指針,遍歷的節(jié)點(diǎn)數(shù)據(jù)打印出來(lái)

54 void bianli(struct node*pH)

55 {

56 //pH->data // 頭節(jié)點(diǎn)數(shù)據(jù),不是鏈表的常規(guī)數(shù)據(jù),不要算進(jìn)去了

57 //struct node *p = pH; // 錯(cuò)誤,因?yàn)轭^指針后面是頭節(jié)點(diǎn)

58 struct node *p = pH->pNext; // p直接走到第一個(gè)節(jié)點(diǎn)

59 printf("-----------開(kāi)始遍歷-----------n");

60 // 是不是最后一個(gè)節(jié)點(diǎn)

61 while (NULL ?。?p->pNext)

62 {

63 printf("node data: %d.n", p->data);

64 p = p->pNext;

65 // 走到下一個(gè)節(jié)點(diǎn),也就是循環(huán)增量

66 }

67 printf("node data: %d.n", p->data);

68 printf("-------------完了-------------n");

69 }

70 // 從鏈表pH中刪除節(jié)點(diǎn),待刪除的節(jié)點(diǎn)的特征是數(shù)據(jù)區(qū)等于data

71 // 返回值:當(dāng)找到并且成功刪除了節(jié)點(diǎn)則返回0,當(dāng)未找到節(jié)點(diǎn)時(shí)返回-1

72 int delete_node(struct node*pH, int data)

73 {

74// 找到這個(gè)待刪除的節(jié)點(diǎn),通過(guò)遍歷鏈表來(lái)查找

75struct node *p = pH; // 用來(lái)指向當(dāng)前節(jié)點(diǎn)

76struct node *pPrev = NULL;// 用來(lái)指向當(dāng)前節(jié)點(diǎn)的前一個(gè)點(diǎn)

77while (NULL ?。?p->pNext)// 是不是最后一個(gè)節(jié)點(diǎn)

78{

79 pPrev = p; // 在p走向下一個(gè)節(jié)點(diǎn)前先將其保存

80 p = p->pNext; // 走到下一個(gè)節(jié)點(diǎn),也就是循環(huán)增量

81 // 判斷這個(gè)節(jié)點(diǎn)是不是我們要找的那個(gè)節(jié)點(diǎn)

82 if (p->data == data)

83 {

84 // 找到了節(jié)點(diǎn),處理這個(gè)節(jié)點(diǎn)

85 // 分為2種情況,一個(gè)是找到的是普通節(jié)點(diǎn),另一個(gè)是找到的是尾節(jié)點(diǎn)

86 // 刪除節(jié)點(diǎn)的困難點(diǎn)在于:通過(guò)鏈表的遍歷依次訪問(wèn)各個(gè)節(jié)點(diǎn),找到這個(gè)節(jié)點(diǎn)

87 // 后p指向了這個(gè)節(jié)點(diǎn),但是要?jiǎng)h除這個(gè)節(jié)點(diǎn)關(guān)鍵要操作前一個(gè)節(jié)點(diǎn),但是這

88 // 時(shí)候已經(jīng)沒(méi)有指針指向前一個(gè)節(jié)點(diǎn)了,所以沒(méi)法操作。解決方案就是增加

89 // 一個(gè)指針指向當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)

90 if (NULL == p->pNext)

91 {

92 // 尾節(jié)點(diǎn)

93 pPrev->pNext = NULL; // 原來(lái)尾節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)變成新尾節(jié)點(diǎn)

94 free(p); // 釋放原來(lái)的尾節(jié)點(diǎn)的內(nèi)存

95 }

96 else

97 {

98 // 普通節(jié)點(diǎn)

99 pPrev->pNext = p->pNext;

100// 要?jiǎng)h除的節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)和它的后一個(gè)節(jié)點(diǎn)相連,這樣就把要?jiǎng)h除的節(jié)點(diǎn)給摘出來(lái)了

101 free(p);

102 }

103 // 處理完成之后退出程序

104 return 0;

105 }

106}

107// 到這里還沒(méi)找到,說(shuō)明鏈表中沒(méi)有我們想要的節(jié)點(diǎn)

108printf("沒(méi)找到這個(gè)節(jié)點(diǎn).n");

109return -1;

110}

111int main(void)

112{

113 // 定義頭指針

114 //struct node *pHeader = NULL;

115 // 這樣直接insert_tail會(huì)段錯(cuò)誤。

116 struct node *pHeader = create_node(0);

117 insert_h(yuǎn)ead(pHeader, create_node(11));

118 insert_h(yuǎn)ead(pHeader, create_node(12));

119 insert_h(yuǎn)ead(pHeader, create_node(13));

120 // 訪問(wèn)鏈表頭節(jié)點(diǎn)的有效數(shù)據(jù)

121 printf("beader node data: %d.n", pHeader->data);

122 bianli(pHeader);

123delete_node(pHeader, 12);

124printf("------------------刪除后-------------n");

125bianli(pHeader);

126 return 0;

127 }

編譯結(jié)果:

1root@ubuntu-virtual-machine:/mnt/hgfs/day# gcc flie1.c

2root@ubuntu-virtual-machine:/mnt/hgfs/day# ./a.out

3beader node data: 3.

4-----------開(kāi)始遍歷-----------

5node data: 13.

6node data: 12.

7node data: 11.

8------------完了-------------

9------------------刪除后-------------

10-----------開(kāi)始遍歷-----------

11node data: 13.

12node data: 11.

13-------------完了-------------

三、鏈表的逆序:

1、什么叫鏈表的逆序?

鏈表的逆序又叫反向,意思就是把鏈表中所有的有效節(jié)點(diǎn)在鏈表中的順序給反過(guò)來(lái)。

2、怎樣實(shí)現(xiàn)鏈表的逆序?

首先遍歷原鏈表,然后將原鏈表中的頭指針和頭節(jié)點(diǎn)作為新鏈表的頭指針和頭節(jié)點(diǎn),原鏈表中的有效節(jié)點(diǎn)挨個(gè)依次取出來(lái),采用頭插入的方法插入新鏈表中即可。

3、實(shí)戰(zhàn)代碼演示:

1 #include <stdio.h>

2 #include <strings.h>

3 #include <stdlib.h>

4// 構(gòu)建一個(gè)鏈表的節(jié)點(diǎn)

5struct node

6 {

7 int data;

8 // 有效數(shù)據(jù)

9 struct node *pNext; // 指向下一個(gè)節(jié)點(diǎn)的指針

10 };

11 // 作用:創(chuàng)建一個(gè)鏈表節(jié)點(diǎn)

12 // 返回值:指針,指針指向我們本函數(shù)新創(chuàng)建的一個(gè)節(jié)點(diǎn)的首地址

13 struct node * create_node(int data)

14 {

15 struct node *p = (struct node

16 *)malloc(sizeof(struct node));

17 if (NULL == p)

18 {

19 printf("malloc error.n");

20 return NULL;

21 }

22 // 清理申請(qǐng)到的堆內(nèi)存

23 bzero(p, sizeof(struct node));

24 // 填充節(jié)點(diǎn)

25 p->data = data;

26 p->pNext = NULL;

27 return p;

28}

29// 計(jì)算添加了新的節(jié)點(diǎn)后總共有多少個(gè)節(jié)點(diǎn),然后把這個(gè)數(shù)寫(xiě)進(jìn)頭節(jié)點(diǎn)中。

30 void insert_tail(struct node *pH, struct node *new)

31{

32 int cnt = 0;

33 // 分兩步來(lái)完成插入

34 // 第一步,先找到鏈表中最后一個(gè)節(jié)點(diǎn)

35 struct node *p = pH;

36 while (NULL ?。?p->pNext)

37 {

38 p = p->pNext; // 往后走一個(gè)節(jié)點(diǎn)

39 cnt++;

40 }

41 // 第二步,將新節(jié)點(diǎn)插入到最后一個(gè)節(jié)點(diǎn)尾部

42 p->pNext = new;

43 pH->data = cnt + 1;

44 }

45 void insert_h(yuǎn)ead(struct node *pH, struct node *new)

46 {

47 // 第1步: 新節(jié)點(diǎn)的next指向原來(lái)的第一個(gè)節(jié)點(diǎn)

48 new->pNext = pH->pNext;

49 // 第2步: 頭節(jié)點(diǎn)的next指向新節(jié)點(diǎn)的地址

50 pH->pNext = new;

51 // 第3步: 頭節(jié)點(diǎn)中的計(jì)數(shù)要加1

52 pH->data += 1;

53 }

54 // 遍歷單鏈表,pH為指向單鏈表的頭指針,遍歷的節(jié)點(diǎn)數(shù)據(jù)打印出來(lái)

55 void bianli(struct node*pH)

56 {

57 //pH->data // 頭節(jié)點(diǎn)數(shù)據(jù),不是鏈表的常規(guī)數(shù)據(jù),不要算進(jìn)去了

58 //struct node *p = pH; // 錯(cuò)誤,因?yàn)轭^指針后面是頭節(jié)點(diǎn)

59 struct node *p = pH->pNext; // p直接走到第一個(gè)節(jié)點(diǎn)

60 printf("-----------開(kāi)始遍歷-----------n");

61 // 是不是最后一個(gè)節(jié)點(diǎn)

62 while (NULL ?。?p->pNext)

63 {

64 printf("node data: %d.n", p->data);

65 p = p->pNext;

66 // 走到下一個(gè)節(jié)點(diǎn),也就是循環(huán)增量

67 }

68 printf("node data: %d.n", p->data);

69 printf("-------------完了-------------n");

70 }

71 // 從鏈表pH中刪除節(jié)點(diǎn),待刪除的節(jié)點(diǎn)的特征是數(shù)據(jù)區(qū)等于data

72// 返回值:當(dāng)找到并且成功刪除了節(jié)點(diǎn)則返回0,當(dāng)未找到節(jié)點(diǎn)時(shí)返回-1

73int delete_node(struct node*pH, int data)

74{

75// 找到這個(gè)待刪除的節(jié)點(diǎn),通過(guò)遍歷鏈表來(lái)查找

76struct node *p = pH;

77 // 用來(lái)指向當(dāng)前節(jié)點(diǎn)

78struct node *pPrev = NULL;

79// 用來(lái)指向當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)

80while (NULL ?。?p->pNext) // 是不是最后一個(gè)節(jié)點(diǎn)

81{

82 pPrev = p; // 在p走向下一個(gè)節(jié)點(diǎn)前先將其保存

83 p = p->pNext; // 走到下一個(gè)節(jié)點(diǎn),也就是循環(huán)增量

84 // 判斷這個(gè)節(jié)點(diǎn)是不是我們要找的那個(gè)節(jié)點(diǎn)

85 if (p->data == data)

86 {

87 // 找到了節(jié)點(diǎn),處理這個(gè)節(jié)點(diǎn)

88 // 分為2種情況,一個(gè)是找到的是普通節(jié)點(diǎn),另一個(gè)是找到的是尾節(jié)點(diǎn)

89 // 刪除節(jié)點(diǎn)的困難點(diǎn)在于:通過(guò)鏈表的遍歷依次訪問(wèn)各個(gè)節(jié)點(diǎn),找到這個(gè)節(jié)點(diǎn)

90 // 后p指向了這個(gè)節(jié)點(diǎn),但是要?jiǎng)h除這個(gè)節(jié)點(diǎn)關(guān)鍵要操作前一個(gè)節(jié)點(diǎn),但是這

91 // 時(shí)候已經(jīng)沒(méi)有指針指向前一個(gè)節(jié)點(diǎn)了,所以沒(méi)法操作。解決方案就是增加

92 // 一個(gè)指針指向當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)

93 if (NULL == p->pNext)

94 {

95 // 尾節(jié)點(diǎn)

96 pPrev->pNext = NULL; // 原來(lái)尾節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)變成新尾節(jié)點(diǎn)

97 free(p); // 釋放原來(lái)的尾節(jié)點(diǎn)的內(nèi)存

98 }

99 else

100 {

101 // 普通節(jié)點(diǎn)

102 pPrev->pNext = p->pNext;

103 // 要?jiǎng)h除的節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)和它的后一個(gè)節(jié)點(diǎn)相連,這樣就把要?jiǎng)h除的節(jié)點(diǎn)給摘出來(lái)了

104 free(p);

105 }

106 // 處理完成之后退出程序

107 return 0;

108 }

109}

110// 到這里還沒(méi)找到,說(shuō)明鏈表中沒(méi)有我們想要的節(jié)點(diǎn)

111printf("沒(méi)找到這個(gè)節(jié)點(diǎn).n");

112return -1;

113}

114 // 將pH指向的鏈表逆序

115 void reverse_linkedlist(struct node *pH)

116 {

117struct node *p = pH->pNext;

118 // pH指向頭節(jié)點(diǎn),p指向第1個(gè)有效節(jié)點(diǎn)

119struct node *pBack;

120 // 保存當(dāng)前節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn)地址

121// 當(dāng)鏈表沒(méi)有有效節(jié)點(diǎn)或者只有一個(gè)有效節(jié)點(diǎn)時(shí),逆序不用做任何操作

122if ((NULL ==p) || (NULL == p->pNext))

123 return;

124// 當(dāng)鏈表有2個(gè)及2個(gè)以上節(jié)點(diǎn)時(shí)才需要真正進(jìn)行逆序操作

125while (NULL ?。?p->pNext) // 是不是最后一個(gè)節(jié)點(diǎn)

126{

127 // 原鏈表中第一個(gè)有效節(jié)點(diǎn)將是逆序后新鏈表的尾節(jié)點(diǎn),尾節(jié)點(diǎn)的pNext指向NULL

128 pBack = p->pNext; // 保存p節(jié)點(diǎn)后面一個(gè)節(jié)點(diǎn)地址

129 if (p == pH->pNext)

130 {

131 // 原鏈表第一個(gè)有效節(jié)點(diǎn)

132 p->pNext = NULL;

133 }

134 else

135 {

136 // 原鏈表的非第1個(gè)有效節(jié)點(diǎn)

137 p->pNext = pH->pNext;

138 }

139 pH->pNext = p;

140 //p = p->pNext; // 這樣已經(jīng)不行了,因?yàn)閜->pNext已經(jīng)被改過(guò)了

141 p = pBack; // 走到下一個(gè)節(jié)點(diǎn)

142}

143// 循環(huán)結(jié)束后,最后一個(gè)節(jié)點(diǎn)仍然缺失

144insert_h(yuǎn)ead(pH, p);

145}

146int main(void)

147{

148 // 定義頭指針

149 //struct node *pHeader = NULL;

150 // 這樣直接insert_tail會(huì)段錯(cuò)誤。

151 struct node *pHeader = create_node(0);

152 insert_h(yuǎn)ead(pHeader, create_node(11));

153 insert_h(yuǎn)ead(pHeader, create_node(12));

154 insert_h(yuǎn)ead(pHeader, create_node(13));

155 // 訪問(wèn)鏈表頭節(jié)點(diǎn)的有效數(shù)據(jù)

156 printf("beader node data: %d.n", pHeader->data);

157 bianli(pHeader);

158reverse_linkedlist(pHeader);

159printf("------------------逆序后-------------n");

160bianli(pHeader);

161 return 0;

162 }

編譯結(jié)果:

1root@ubuntu-virtual-machine:/mnt/hgfs/day# gcc

2 flie1.c

3root@ubuntu-virtual-machine:/mnt/hgfs/day#

4./a.out

5 beader node data: 3.

6 -----------開(kāi)始遍歷-----------

7 node data: 13.

8 node data: 12.

9 node data: 11.

10 -------------完了-------------

11 ------------------逆序后-------------

12 -----------開(kāi)始遍歷-----------

13 node data: 11.

14 node data: 12.

15 node data: 13.

16 -------------完了-------------

四、總結(jié):

通過(guò)兩天的單鏈表學(xué)習(xí),讓自己理解更加深刻,不過(guò)學(xué)的東西還是最后能夠用到實(shí)戰(zhàn)當(dāng)中去,這樣才是最后的學(xué)習(xí)方法!

每天學(xué)一點(diǎn),日積月累就有質(zhì)的提升!如果您覺(jué)得好,可以給關(guān)注哦,這是對(duì)我的最大鼓勵(lì)哦;我會(huì)繼續(xù)努力加油的

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深度學(xué)習(xí)驅(qū)動(dòng)的構(gòu)表面設(shè)計(jì)進(jìn)展及其在全息成像中的應(yīng)用

    當(dāng)前,深度學(xué)習(xí)技術(shù)與構(gòu)表面(metasurface)全息成像技術(shù)的融合,有力推動(dòng)了光學(xué)成像領(lǐng)域的發(fā)展。得益于構(gòu)表面對(duì)光波特性的精準(zhǔn)調(diào)控,全息成像技術(shù)經(jīng)處理后可生成對(duì)應(yīng)的三維圖像。因此,
    的頭像 發(fā)表于 04-09 13:55 ?172次閱讀
    深度<b class='flag-5'>學(xué)習(xí)</b>驅(qū)動(dòng)的<b class='flag-5'>超</b>構(gòu)表面設(shè)計(jì)進(jìn)展及其在全息成像中的應(yīng)用

    ATX電源電路分析詳解開(kāi)關(guān)電源的原理

    ATX電源電路分析詳解開(kāi)關(guān)電源的原理,WORD版,圖文并茂,詳細(xì)說(shuō)明各個(gè)元件在電路中的作用。適合初學(xué)者
    發(fā)表于 03-29 16:47 ?3次下載

    新能源光伏涉網(wǎng)試驗(yàn)運(yùn)維檢修設(shè)備詳解

    新能源光伏涉網(wǎng)試驗(yàn)運(yùn)維設(shè)備及相關(guān)設(shè)備配置、人員配置、資質(zhì)證明證書(shū)等詳細(xì)說(shuō)明
    的頭像 發(fā)表于 03-11 11:39 ?405次閱讀

    氬弧焊機(jī)工作原理詳細(xì)說(shuō)明和具體維修方法

    非常適合新老維修高手的查閱,個(gè)人學(xué)習(xí)一周后獲益匪淺
    發(fā)表于 12-18 13:58

    無(wú)數(shù)據(jù)域雙向鏈表的代碼

    下面是一個(gè)簡(jiǎn)單的示例,演示了如何使用無(wú)數(shù)據(jù)域雙向鏈表進(jìn)行插入和訪問(wèn)操作: #include #include// 包含offsetof宏 // 定義節(jié)點(diǎn)結(jié)構(gòu)體 struct Node
    發(fā)表于 12-11 06:56

    LUA例程-常用的回調(diào)函數(shù)使用說(shuō)明

    詳細(xì)說(shuō)明LUA腳本函數(shù)功能和對(duì)應(yīng)的應(yīng)用實(shí)例。對(duì)于LUA腳本編程有很大的幫助和提高技能。
    發(fā)表于 11-24 16:43 ?0次下載

    選型手冊(cè):MBR20150A 系列肖特基勢(shì)壘整流極管

    從品牌定位、器件特性、電氣參數(shù)等維度展開(kāi)詳細(xì)說(shuō)明。一、品牌背景:仁懋電子(MOT)與功率整流器件布局仁懋電子(MOT)聚焦功率半導(dǎo)體全品類研發(fā),在大電流肖特基
    的頭像 發(fā)表于 10-28 17:52 ?685次閱讀
    選型手冊(cè):MBR20150A 系列肖特基勢(shì)壘整流<b class='flag-5'>二</b>極管

    rt_object_get_information獲取到的鏈表為空怎么解決?

    rtt啟動(dòng)過(guò)程,在初始化堆的時(shí)候,進(jìn)入rt_object_init,調(diào)用rt_object_get_information獲取到的鏈表為空,導(dǎo)致系統(tǒng)起不來(lái)。
    發(fā)表于 10-11 11:44

    運(yùn)算放大器的使用詳細(xì)說(shuō)明

    運(yùn)算放大器權(quán)威指南 第三版 獲取完整文檔資料可下載附件哦?。。?! 如果內(nèi)容有幫助可以關(guān)注、點(diǎn)贊、評(píng)論支持一下哦~
    發(fā)表于 08-01 13:51

    表面貼裝 0402 硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管 skyworksinc

    電子發(fā)燒友網(wǎng)為你提供()表面貼裝 0402 硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊(cè),更有表面貼裝 0402 硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管的引腳圖、接線圖、封裝手冊(cè)、中文資料、英文資料,
    發(fā)表于 07-11 18:33
    表面貼裝 0402 硅<b class='flag-5'>超</b>突變調(diào)諧變?nèi)?b class='flag-5'>二</b>極管 skyworksinc

    表面貼裝、硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管 skyworksinc

    電子發(fā)燒友網(wǎng)為你提供()表面貼裝、硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊(cè),更有表面貼裝、硅突變調(diào)諧變?nèi)?b class='flag-5'>二極管的引腳圖、接線圖、封裝手冊(cè)、中文資料、英文資料,表面貼裝、硅
    發(fā)表于 07-11 18:32
    表面貼裝、硅<b class='flag-5'>超</b>突變調(diào)諧變?nèi)?b class='flag-5'>二</b>極管 skyworksinc

    目前Mirco Python sdk觸摸到底支持什么驅(qū)動(dòng)啊 ?

    目前的Mirco Python sdk觸摸到底支持什么驅(qū)動(dòng)啊 能不能有資料詳細(xì)說(shuō)明 GT911 觸摸驅(qū)動(dòng)是否支持啊
    發(fā)表于 06-24 07:02

    磁珠與電感的對(duì)比

    本文分三部分,詳細(xì)的描述了電感的定義、磁珠的定義以及對(duì)比了磁珠與電感的區(qū)別,通過(guò)舉例方式詳細(xì)說(shuō)明了磁珠的應(yīng)用場(chǎng)合和使用方法
    發(fā)表于 05-29 15:50

    貼片三極管上的印字與真實(shí)名稱的對(duì)照表詳細(xì)說(shuō)明

      本文檔的主要內(nèi)容詳細(xì)介紹的是貼片三極管上的印字與真實(shí)名稱的對(duì)照表詳細(xì)說(shuō)明
    發(fā)表于 05-28 09:05 ?110次下載

    瑞芯微rv1106開(kāi)發(fā)資料 rv1106數(shù)據(jù)手冊(cè) rv1106詳細(xì)說(shuō)明書(shū)免費(fèi)下載

    瑞芯微rv1106開(kāi)發(fā)資料 rv1106數(shù)據(jù)手冊(cè) rv1106詳細(xì)說(shuō)明書(shū)免費(fèi)下載
    的頭像 發(fā)表于 05-19 11:16 ?7401次閱讀
    瑞芯微rv1106開(kāi)發(fā)資料 rv1106數(shù)據(jù)手冊(cè) rv1106<b class='flag-5'>詳細(xì)說(shuō)明</b>書(shū)免費(fèi)下載
    肃北| 高阳县| 仁怀市| 塘沽区| 蓬莱市| 东港市| 唐山市| 句容市| 黄浦区| 泰州市| 广东省| 岢岚县| 门头沟区| 永福县| 无锡市| 剑阁县| 惠安县| 海兴县| 建湖县| 中卫市| 江城| 鞍山市| 长海县| 阿拉善右旗| 大理市| 达孜县| 大埔县| 依兰县| 海兴县| 仁怀市| 从化市| 阆中市| 张掖市| 自贡市| 青阳县| 民勤县| 芮城县| 崇州市| 竹溪县| 渝中区| 崇义县|