如何用尾插法建立双链表

其实本来是想完成汪队给的链表快排的作业,但是我写完建立双链表以后就12点了龟龟,明天还要早起QAQ,我菜死了

一,为啥要有双链表

先说单链表吧
单链表长这样

他的一个结点结构就是

【元素域 | next指针域】

每次后插法进行单链表的建立时,上一个的结点里的指针域都会指向下一个结点,比如上图的第一个结点(e1元素所在结点,蓝色阴影结点为头结点)的指针域就指向了下一个结点

以此类推

我们就可以得到一个由指针链接的链表,这就叫单链表

我们可以看到,如果我有某元素所在结点的指针域是可以很轻松在这个元素所在结点的左右进行结点的插入的

但是!!!如果我想在这个元素的前一个元素进行前插的话,我必须又要将这个表从头开始遍历一遍,这就大大浪费了时间(就是在开车在单行线不能掉头)

所以我们引入了双链表

二,双链表的建立

双链表长下面这样

他的一个节点结构就是

【prior指针域 | 元素域 | next指针域】

双链表就比上面的单链表多了一个“prior指针域”,prior是指向前一个结点的针,next和上面的单链表一样都是指向后面的一个结点指针

回到上面的问题

如果我们还要进行在某个元素的前一个元素进行前插的话,用双链表就会快很多

因为我们不再需要去从头开始遍历整个表,双链表的每个结点都存着的上一个结点的地址

我们只需要将指针前移就能完成(单行线变双行线虚线!随时可以掉头回去)

下面就是如何建立双链表的步骤

1.双链表的结点类型定义

 typedef struct DNode{
int data;
struct DNode *prior, *next;
}DNode, *DLinkList;

定义了一个元素域(我这里用的int类型,可更换),两个指针域*prior和*next,分别用来指向该结点的前一个结点和后一个结点

2.双链表的建立

 DLinkList DList_Create(DLinkList &D)
{
int num;
scanf("%d",&num);
D = (DNode*)malloc(sizeof(DNode)); //定义头结点
DNode *s,*p = D;//s为待插入结点的指针
p->next = NULL;
while(num != -)//输入-1时停止
{
s = (DNode*)malloc(sizeof(DNode));//为待插入的s申请空间
s->data = num;
s->next = p->next;//s的next复制上一个结点p的next域
p->next = s;//上一个结点p的next指向s
s->prior = p;//s的prior指向前一个结点p
p = p->next;//p指针后移一位
scanf("%d",&num);//下个元素的值
}
return D;
}

while里的步骤如下

s = (DNode*)malloc(sizeof(DNode));//为待插入的s申请空间

s->next = p->next;//s的next复制上一个结点p的next域 

p->next = s;//上一个结点p的next指向s

s->prior = p;//s的prior指向前一个结点p

p = p->next;//p指针后移一位 

现在1.22了再不睡我就要猝死了,链表快排要不明天抄作业叭

嘿嘿

如何用尾插法建立双链表(C语言,非循环)的更多相关文章

  1. C实现头插法和尾插法来构建单链表(不带头结点)

    链表的构建事实上也就是不断插入节点的过程.而节点的插入能够分为头插法和尾插法. 头插法就是在头结点后插入该节点,始终把该节点作为第一个节点.尾插法就是在链表的最后一个节点处插入元素,作为最后一个节点. ...

  2. c语言——单链表分拆——头插法创建链表,尾插法生成链表

    #if 1 #include<stdio.h> #include<stdlib.h> #include<iostream> using namespace std; ...

  3. Java解释单链表中的头插法以及尾插法

    单链表属于数据结构中的一种基本结构,是一种线性结构,在此使用Java对其中的头插法以及尾插法进行解释. 首先定义好链表中的节点类: 其中,data代表节点所存放的数据,next代表指向下一节点 对于单 ...

  4. C实现头插法和尾插法来构建单链表(带头结点)

    我在之前一篇博客<C实现头插法和尾插法来构建单链表(不带头结点)>中具体实现了怎样使用头插法和尾插法来建立一个不带头结点的单链表,可是在实际使用中.我们用的最多的还是带头结点的单链表.今天 ...

  5. 7-19 求链式线性表的倒数第K项(20 分)(单链表定义与尾插法)

    给定一系列正整数,请设计一个尽可能高效的算法,查找倒数第K个位置上的数字. 输入格式: 输入首先给出一个正整数K,随后是若干正整数,最后以一个负整数表示结尾(该负数不算在序列内,不要处理). 输出格式 ...

  6. 尾插法-实现链表反转(有点bug,以后再来研究下)

    def func2(head): p = head.next while p.next: q = p.next p.next = q.next # 重点 head.next = q q.next = ...

  7. LinkedList 利用的是尾插法

  8. 20140502 static_cast和dynamic_cast的类型检查 双链表建立,删除,打印

    1.static_cast和dynamic_cast的类型检查 static_cast的类型检查:只检查无关类之间的转换 CBaseY* pY1 = static_cast<CBaseY*> ...

  9. HashMap 链表插入方式 → 头插为何改成尾插 ?

    开心一刻 一天,楼主在路上碰到了一个很久没见的朋友,找了个餐馆,坐下聊了起来 楼主:在哪上班了 ? 朋友:火葬场啊 楼主:在那上班,一个月多少钱啊 ? 朋友:两万多啊 楼主(不可思议):多少 ? 朋友 ...

随机推荐

  1. .NET Core下的开源分布式任务调度系统ScheduleMaster-v2.0低调发布

    从1月份首次公开介绍这个项目到现在也快4个月了,期间做了一些修修补补整体没什么大的改动.2.0算是发布之后第一个大的版本更新,带来了许多新功能新特性,也修复了一些已知的bug,在此感谢在博客.Issu ...

  2. synchronized 的实现原理

    加不加 synchronized 有什么区别? synchronized 作为悲观锁,锁住了什么? synchronized 代码块怎么用 前面 3 篇文章讲了 synchronized 的同步方法和 ...

  3. dockerfile构架镜像(8)

    nginx镜像的构建 先查看下本地的镜像,选取官网的centos作为base image: [root@server ~]# docker images 创建一个目录专门用来存放的目录,也就是Dock ...

  4. cut,xargs,sort,tr,rename命令解析

    cut 文件内容查看 显示行中的指定部分,删除文件中指定字段 显示文件的内容,类似于下的type命令. 语法: cut(选项)(参数) 选项: -b:仅显示行中指定直接范围的内容: -c:仅显示行中指 ...

  5. while循环脚本

    [root@oldboy ~]# (while :;do date;sleep 5;done)& fg ctrl c退出 fg ( while :; do date; sleep 5; don ...

  6. 解析HTML、JS与PHP之间的数据传输

    在电商网站搭建过程中,前端经常会向后端请求数据,有时候通过HTML.JS和PHP文件的处理来实现数据的连通.通常情况下,用户在HTML中做关键字操作,JS对提交的表单进行数据处理,向后端发起ajax请 ...

  7. INTERVIEW #3

    菊厂的面试本来没打算记录,因为当时投的是非技术岗(技术支持).为了全面,就寥做记录. 菊厂的面试因为有口头保密协议,所以不能透露具体题目. 0 群面 简历通过筛选后,会有短信通知去面试. 非技术岗第一 ...

  8. USACO Training Section 1.2 挤牛奶Milking Cows

    题目描述 三个农民每天清晨5点起床,然后去牛棚给3头牛挤奶.第一个农民在300秒(从5点开始计时)给他的牛挤奶,一直到1000秒.第二个农民在700秒开始,在 1200秒结束.第三个农民在1500秒开 ...

  9. 在Jetson TX2上捕获、显示摄像头视频

    参考文章:How to Capture and Display Camera Video with Python on Jetson TX2 与参考文章大部分都是相似的,如果不习惯看英文,可以看看我下 ...

  10. 如何使用简单 PHP 对象 POPO (Plain old PHP Object) 来优化你的代码

    如果您熟悉 Java,可能您已经知道 POJO (普通 Java 类). 因为 POJO 这个词最早是由 Martin Fowler.Rebecca Parsons 和 Josh MacKenzie ...