栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

#include 
#include 
//定义单链表结构体 
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->datadata) 
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("插入成功!!!nn"); 
break; 
} 
scanf("%d",&op); 
} 
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/65722.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号