全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

数据结构 双向链表的创建和读取详解及实例代码

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

双向链表是为了满足更加方便的查找前驱,而付出空间的代价的一个数据结构。双向链表的节点定义如下:

 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小时内与您取得联系。