• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C语言单链表常见操作汇总

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c语言单链表,c语言单链表排序,c语言创建单链表,c语言建立单链表,c语言单链表逆序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

#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); 
} 
}
</div> </div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言数据结构实现链表逆序并输出
  • C语言解字符串逆序和单向链表逆序问题的代码示例
  • C语言单链表的实现
  • C语言之单链表的插入、删除与查找
  • C语言实现单链表逆序与逆序输出实例
  • C语言单链表常见操作汇总
  • c语言链表操作示例分享
  • c语言链表基本操作(带有创建链表 删除 打印 插入)
  • 用C语言实现单链表的各种操作(二)
  • 用C语言实现单链表的各种操作(一)

相关文章

  • 2017-05-28用C语言实现单链表的各种操作(一)
  • 2017-05-28深入理解void以及void指针的含义
  • 2017-05-28基于C语言实现简单的走迷宫游戏
  • 2017-05-28详解C++中的对象指针与对象数组
  • 2017-05-28C++中delete和delete[]的区别
  • 2017-05-28详解Linux的SOCKET编程
  • 2017-05-28C语言基础 原码、反码、补码和移码详解
  • 2017-05-28总结UNIX/LINUX下C++程序计时的方法
  • 2017-05-28C语言实现最长递增子序列问题的解决方法
  • 2017-05-28C++中求旋转数组中的最小数字(经典面试题)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Linux下C语言实现C/S模式编程
    • C++中函数的默认参数详细解析
    • ipv6实现tcp编程示例
    • C++函数模板与类模板实例解析
    • C++中十种内部排序算法的比较分析
    • C语言fopen函数的用法,C语言打开文件详解
    • Swift编程中的泛型解析
    • 基于C++中常见编译错误的总结详解
    • Windows系统下使用C语言编写单线程的文件备份程序
    • c++拷贝构造函数防篡改示例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有