数据结构 双向链表的创建和读取

双向链表是为了满足更加方便的查找前驱,而付出空间的代价的一个数据结构。双向链表的节点定义如下:
typedef struct node
{
int x;
struct node *prior,*next;
}DLNode;
双向链表的空间结构如下图所示:
双向链表的创建如下:
//创建双向链表
DLNode *create_DList()
{
DLNode *p,*h,*l;
int n,i,x;
h = (DLNode *)malloc(sizeof(DLNode));
h->prior = h; //当空的双向链表就像上图那样前驱和后驱都会指向自己;
h->next = h;
p = h;
printf("请输入需要创建双向链表的长度:");
scanf("%d",&n);
for(i = 0; i < n; i++)
{
printf("请输入第%d个数",i+1);
scanf("%d",&x);
l = (DLNode *)malloc(sizeof(DLNode));
l->x = x;
p->next = l;
l->prior = p;
l->next = h; //注意,l->next链接的是头节点,
h->prior = l; //而头结点的前驱是l。 这样便构成了一个循环的双向链表
p = l;
}
return(h); //不要忘记返回链表
}
上面绿颜色的字需要注意;
读取双向链表的代码如下:
void out_DList(DLNode *l)
{
DLNode *p;
int i;
p = l;
p = p->next;
while(p!=l) //注意条件发生了变化
{
printf("%5d",p->x);
p = p->next; //不要忘记让p指向下一个节点;
}
}
注意:①:由于头节点的值为空,所以p = p->next; ②:循环的条件发生了变化,因为这是一个循环链表,链表的尾部指向头部,所以条件是p!=l;
全部代码如下:
#include<stdio.h>
#include <stdlib.h>
typedef struct node
{
int x;
struct node *prior,*next;
}DLNode;
//函数声明
DLNode *create_DList();
void out_DList(DLNode *l);
main()
{
DLNode *l;
l = create_DList();
printf("创建成功!");
out_DList(l);
}
//读取双向链表
void out_DList(DLNode *l)
{
DLNode *p;
int i;
p = l;
p = p->next;
while(p!=l)
{
printf("%5d",p->x);
p = p->next;
}
}
//创建双向链表
DLNode *create_DList()
{
DLNode *p,*h,*l;
int n,i,x;
h = (DLNode *)malloc(sizeof(DLNode));
h->prior = h;
h->next = h;
p = h;
printf("请输入需要创建双向链表的长度:");
scanf("%d",&n);
for(i = 0; i < n; i++)
{
printf("请输入第%d个数",i+1);
scanf("%d",&x);
l = (DLNode *)malloc(sizeof(DLNode));
l->x = x;
p->next = l;
l->prior = p;
l->next = h;
h->prior = l;
p = l;
}
return(h);
}
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# 数据结构
# 双向链表
# 双向链表结构
# C语言 数据结构双向链表简单实例
# C#数据结构之双向链表(DbLinkList)实例详解
# java数据结构之实现双向链表的示例
# C#数据结构与算法揭秘四 双向链表
# C语言实现数据结构和双向链表操作
# 链表
# 请输入
# 不要忘记
# 的是
# 发生了
# 就像
# 这是一个
# 希望能
# 当空
# 所示
# 谢谢大家
# 需要注意
# 值为
# 如下图
# 上图
# 是为了
# 构成了
# pre
# DLNode
相关文章:
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
已有域名和空间如何搭建网站?
Android自定义控件实现温度旋转按钮效果
如何快速完成中国万网建站详细流程?
如何在万网ECS上快速搭建专属网站?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
建站主机功能解析:服务器选择与快速搭建指南
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
如何制作网站标识牌,动态网站如何制作(教程)?
Swift开发中switch语句值绑定模式
建站上传速度慢?如何优化加速网站加载效率?
如何配置支付宝与微信支付功能?
清除minerd进程的简单方法
建站之星如何助力网站排名飙升?揭秘高效技巧
全景视频制作网站有哪些,全景图怎么做成网页?
高防服务器租用指南:配置选择与快速部署攻略
建站之星后台管理系统如何操作?
如何在Windows环境下新建FTP站点并设置权限?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
利用JavaScript实现拖拽改变元素大小
如何选择高效稳定的ISP建站解决方案?
b2c电商网站制作流程,b2c水平综合的电商平台?
建站之星收费标准详解:套餐费用及年费价格表一览
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何快速搭建响应式可视化网站?
油猴 教程,油猴搜脚本为什么会网页无法显示?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
平台云上自主建站:模板化设计与智能工具打造高效网站
如何通过FTP空间快速搭建安全高效网站?
网站按钮制作软件,如何实现网页中按钮的自动点击?
如何选择CMS系统实现快速建站与SEO优化?
公司网站设计制作厂家,怎么创建自己的一个网站?
网站制作公司,橙子建站是合法的吗?
小型网站制作HTML,*游戏网站怎么搭建?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
,交易猫的商品怎么发布到网站上去?
建设网站制作价格,怎样建立自己的公司网站?
实例解析angularjs的filter过滤器
如何配置FTP站点权限与安全设置?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
如何正确下载安装西数主机建站助手?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
建站三合一如何选?哪家性价比更高?
如何通过可视化优化提升建站效果?
建站主机与虚拟主机有何区别?如何选择最优方案?
如何快速使用云服务器搭建个人网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。