C语言单链表常见操作汇总

2025-05-27 0 60

C语言单链表是常用的数据结构之一,本文总结了单链表的常见操作,实例如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192
#include<stdio.h>

#include<stdlib.h>

//定义单链表结构体

typedef int ElemType;

typedef struct Node

{

ElemType data;

struct Node *next;

}LNode,*LinkList;

//创建单链表

void Build(LinkList L)

{

int n;

LinkList p,q;

p=L;

printf("请输入n和n个元素:\\n");

scanf("%d",&n);

while(n--)

{

q=(LinkList)malloc(sizeof(LNode));

scanf("%d",&q->data);

q->next = NULL;

p->next=q;

p=q;

}

}

//求单链表的长度

void LinkLength(LinkList L)

{

int num = 0;

LinkList p;

p=L->next;

while(p)

{

num++;

printf("%3d",p->data);

p=p->next;

}

printf("长度为:%d",num);

}

//查找前驱结点

void Find(LinkList L,int x)

{

LinkList p,q;

p=L;

while(p->next &&p->next->data!=x)

p=p->next;

if(p->next)

printf("%d的前驱结点为%d",x,p->data);

else

printf("没有找到");

}

//删除结点值为x的元素

void Delete(LinkList L,int x)

{

LinkList p,q;

p=L;

while(p->next && p->next->data!=x)

p=p->next;

if(p->next)

{

q=p->next;

p->next=q->next;

free(q);

}

printf("删除成功!!");

}

//将表中的元素逆置

void Reverse(LinkList L)

{

LinkList p,q;

p=q=L->next;

L->next=NULL;

while(p)

{

q=q->next;

p->next=L->next;

L->next=p;

p=q;

}

printf("逆置成功!!");

}

//对单链表排序

void sort(LinkList L)

{

LinkList p,q;

int temp;

p=L;

for(p=L;p->next!=NULL;p=p->next)

{

for(q=p->next;q!=NULL;q=q->next)

if(p->data>q->data)

{

temp=p->data;

p->data=q->data;

q->data=temp;

}

}

printf("排序成功!");

}

//删除相同元素

void Deletesameelem(LinkList L)

{

LinkList p,q,s;

p=L;

q=L->next;

while(q->next)

{

if(q->data ==q->next->data)

{

p->next=q->next;

s=q;

q=q->next;

free(s);

}

else

{

p=p->next;

q=q->next;

}

}

printf("删除成功!!");

}

//在升序链表中,插入新的元素,扔有序

void Insert(LinkList L,LinkList p)

{

LinkList s;

s=L;

while(s->next && s->next->data<p->data)

s=s->next;

p->next=s->next;

s->next=p;

}

//提示界面显示

void Tips()

{

printf("\\n");

printf("根据按键选择相应的操作:\\n");

printf("<1>输出单链表及其长度:\\n");

printf("<2>查找值为x的直接前驱结点:\\n");

printf("<3>删除值为x的结点:\\n");

printf("<4>将表中的元素逆置:\\n");

printf("<5>将单链表由小到大进行排序:\\n");

printf("<6>删除表中相同的元素:\\n");

printf("<7>在升序链表中插入元素x:\\n");

printf("<0>退出:\\n");

}

//主函数

void main()

{

int op,x;

LinkList L,p;

L = (LinkList)malloc(sizeof(LNode));

L->next=NULL;

L->data=-1;

Build(L);

Tips();

scanf("%d",&op);

while(op)

{

switch(op)

{

case 1:LinkLength(L);

break;

case 2:

printf("请输入要查找的元素x:\\n");

scanf("%d",&x);

Find(L,x);

break;

case 3:

printf("请输入要删除的元素x:\\n");

scanf("%d",&x);

Delete(L,x);

break;

case 4:Reverse(L);

break;

case 5:sort(L);

break;

case 6:Deletesameelem(L);

break;

case 7:

printf("请输入要插入的元素X:\\n");

scanf("%d",&x);

p=(LinkList)malloc(sizeof(LNode));

p->data=x;

Insert(L,p);

printf("插入成功!!!\\n\\n");

break;

}

scanf("%d",&op);

}

}

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C语言单链表常见操作汇总 https://www.kuaiidc.com/75889.html

相关文章

猜你喜欢
发表评论
暂无评论