链表:C语言描述

链表 linked list

定义

就是一些包含数据的独立数据结构的集合。链表中每个节点通过链或指针连接在一起。程序通过指针访问链表中节点。

单链表

每个节点包含一个指向下一个节点的指针,链表最后一个节点的指针字段的值为NULL,提示链表后不再有其他节点。

  • 通过链表第一个节点可以访问剩余所有的节点。
  • 根指针(root pointer)指向链表的第一个节点。
typedef struct NODE{
    struct NODE *link;
    int value;
}Node;

单链表的插入

将新节点插入到一个有序的单链表中

  • 插入函数需要检查是否到达链表的尾部
  • root是一个指针
  • 为新节点分配内存时是否成功
#define FALSE 0
#define TRUE 1

int sll_insert(Node **linkp,int new_value){
    Node *current;
    Mode *new;
    
    //寻找正确插入位置:按序访问链表
    while((current = *linkp) != NULL && current->value < new_value)
    linkp = &current -> link;
    
    // 为新节点分配内存
    new = (Node *)malloc(sizeof(Node));
    
    // 如果内存分配失败返回false
    if(new == NULL)
    return FALSE;
    
    // 将新值存到新节点中
    new->value = new_value;
    new->link = current;
    
    return TRUE;
}

双链表

每个节点都包含两个指针:指向前一个节点的指针和指向后一个节点的指针

typedef struct NODE{
    struct NODE *fwd;
    struct NODE *bwd;
    int value;
}Node;

根节点

  • 根节点fwd字段指向链表的第一个节点
  • 根节点bwd字段指向链表的最后一个节点
  • 如果量表为空,则两个字段都为NULL

双链表的插入

编写一个当插入值原先不存在于链表中才插入的插入函数

将节点插入到链表中,可能出现的四种情况

  1. 新值插入到链表的中间位置
  2. 新值插入到链表的起始位置
  3. 新值插入到链表的结束位置
  4. 原链表为空的情况下,插入的位置既是起始位置又是结束位置
int dll_insert(Node *rootp,int value){
    Node *this;
    Node *next;
    Node *new;
    
    for(this = rootp;(next = this->fwd) != NULL;this = next){
        if(next->value == value)
        return 0;
        if(next->value>value)
        break;
    }
    new = (Node *)malloc(sizeof(node));
    
    if(new == NULL)
    return -1;
    
    new->value = value;
    
    newnode->fwd = next;
    this->fwd = new;
    
    if(this != rootp)
    new->bwd = this;
    else
    new->bwd = NULL;
    
    if(next != NULL)
    next->bwd = new;
    else
    rootp->bwd - new;
    
    return 1;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,016评论 0 12
  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,471评论 24 1,002
  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 4,373评论 1 31
  • 一、 C/C++程序基础 面试例题1——分析代码写输出(一般赋值语句的概念和方法)。 面试例题2—...
    LuckTime阅读 1,925评论 2 42
  • 夏,将它的气息挥洒于天地,像一篇散文,一首绝句。纵情释放间,苦了透蓝的天空下,苦读的学子,辛劳的人们。已有...
    刘礼状阅读 269评论 0 0