如何用尾插法建立双链表

其实本来是想完成汪队给的链表快排的作业,但是我写完建立双链表以后就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. Java中的二分查找

    二分查找:(折半查找) 前提:数组必须是有序的. 思想:每次都猜中间的那个元素,比较大或者小,就能减少一半的元素.思路:A:定义最小索引,最大索引. B:比较出中间索引 C:拿中间索引的值和要查找的元 ...

  2. solr管理集合

    其实完全版的管理,在web页面上就有. 同时,在官网文档上,也有:https://lucene.apache.org/solr/guide/6_6/coreadmin-api.html#CoreAdm ...

  3. shift count is too large

    STM8S是8 bit单片机在STM8S中 unsigned long是32位, unsigned short和unsigned int都是16位,unsigned char是8位. 以以下代码编译时 ...

  4. MySQL的远程链接

    安装好我们的mMySQL,是不是也有种无从下手的感觉,不用怕,接下来我们可以使用远程连接来可视化我们的数据库的数据: 1. 打开我们的数据库,帐号是root,密码查看文件就行了 2.使用命令: mys ...

  5. MySQL系列(四)

    本章内容: 主从复制 简介原理 Mysql主从同步脚本部署 读写分离 如果主宕机了,怎么办? 双主的情况 MySQL 备份及恢复方案 备份单个及多个数据库 mysqldump 的常用参数 如何增量恢复 ...

  6. java并发中的Synchronized关键词

    文章目录 为什么要同步 Synchronized关键词 Synchronized Instance Methods Synchronized Static Methods Synchronized B ...

  7. QQ网站的源代码

    链接:https://pan.baidu.com/s/1mqetTbauKTI0KJOaU8wW5A 提取码请加QQ:2669803073获取 声明:仅供学习,切勿用于其他用途

  8. Nginx访问日志.Nginx日志切割

    11月27日任务 12.10 Nginx访问日志12.11 Nginx日志切割12.12 静态文件不记录日志和过期时间 1.Nginx访问日志 示例一: 日志格式 vim /usr/local/ngi ...

  9. CodeForces - 140A New Year Table (几何题)当时没想出来-----补题

    A. New Year Table time limit per test2 seconds memory limit per test256 megabytes inputstandard inpu ...

  10. CodeForces-259B]Little Elephant and Magic Square

      Little Elephant loves magic squares very much. A magic square is a 3 × 3 table, each cell contains ...