全网整合营销服务商

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

免费咨询热线: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 


相关文章: 网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  已有域名和空间如何搭建网站?  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小时内与您取得联系。