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

双向链表是为了满足更加方便的查找前驱,而付出空间的代价的一个数据结构。双向链表的节点定义如下:
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
相关文章:
长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?
焦点电影公司作品,电影焦点结局是什么?
如何用好域名打造高点击率的自主建站?
北京企业网站设计制作公司,北京铁路集团官方网站?
网站设计制作企业有哪些,抖音官网主页怎么设置?
实现虚拟支付需哪些建站技术支撑?
建站之星安装后如何自定义网站颜色与字体?
香港服务器租用每月最低只需15元?
电商网站制作公司有哪些,1688网是什么意思?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
网站制作免费,什么网站能看正片电影?
临沂网站制作公司有哪些,临沂第四中学官网?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
详解jQuery中基本的动画方法
建站主机是什么?如何选择适合的建站主机?
如何在云主机快速搭建网站站点?
如何在阿里云虚拟主机上快速搭建个人网站?
浅析上传头像示例及其注意事项
香港服务器选型指南:免备案配置与高效建站方案解析
如何快速查询域名建站关键信息?
建站之星免费模板:自助建站系统与智能响应式一键生成
如何配置WinSCP新建站点的密钥验证步骤?
如何在IIS中新建站点并配置端口与物理路径?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
网站制作说明怎么写,简述网页设计的流程并说明原因?
建站之星云端配置指南:模板选择与SEO优化一键生成
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
网站制作壁纸教程视频,电脑壁纸网站?
如何选择服务器才能高效搭建专属网站?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站三合一如何选?哪家性价比更高?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
独立制作一个网站多少钱,建立网站需要花多少钱?
网站制作软件有哪些,制图软件有哪些?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
免费视频制作网站,更新又快又好的免费电影网站?
郑州企业网站制作公司,郑州招聘网站有哪些?
如何制作网站标识牌,动态网站如何制作(教程)?
存储型VPS适合搭建中小型网站吗?
北京专业网站制作设计师招聘,北京白云观官方网站?
历史网站制作软件,华为如何找回被删除的网站?
javascript基本数据类型及类型检测常用方法小结
制作网站的模板软件,网站怎么建设?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
*请认真填写需求信息,我们会在24小时内与您取得联系。