首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数据结构-链表

    链表是一种常见的重要的数据结构,他的特点是动态地进行存储分配。 1.链表有哪些优势? 举个栗子:如果事先不知道不知道要存放的数据的长度,就要把数组定的足够大。如果要用同一个数组存放不同长度的数据时,就要选择数据长度最长的那个作为数组的长度。链表能够比较好的解决这两种情况。 2.什么是链表? 链表有一个“头指针”,它指向一个元素,这个元素在链表中被称为“结点”,而每一个“结点”应该包含两个部分:用户需要的数据和下一个结点的地址(指针)。这样结点与结点相互连接之后知道最后一个“表尾”,他的指向下个结点的地址(指针)为NULL。至此,链表结束。 3.链表中存放的地址是不连续的? 想要访问一个链表,必须知道链表的“头指针”。 4.如何建立一个链表? 用结构体变量建立链表最为合适。

    01

    建立单链表相关问题详解

    相信学习程序编程的各位猿友们对链表再熟悉不过了,这是我们在学数据结构时遇到的一种存储结构,在链表的问题上,并不是我们想的那样简单,当然,也不是那么难。对于初学者来说,未免是抽象而复杂的,我们常常以为,抽象的东西当当然需要去抽象的理解,我们常常看到书上这样写,抽象数据结构,那些定义的方式,常常让初学者有点懵懂。数据结构的东西很需要强大的逻辑思维去理解,算法的问题通常并不是很好去解决,逻辑思维其实并不是先天的,更重要的是我们在后天的学习过程中建立这种思维。就像我们脑子里常常建立的突触一样,多思考,多操作,你才能变得聪明。所以,对此我们应怀有信心和激情。 链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。 相比于线性表顺序结构,操作复杂。由于不必须按顺序存储,链表在插入的时候可以达到O(1)的复杂度,比另一种线性表顺序表快得多,但是查找一个节点或者访问特定编号的节点则需要O(n)的时间,而线性表和顺序表相应的时间复杂度分别是O(logn)和O(1)。 使用链表结构可以克服数组链表需要预先知道数据大小的缺点,链表结构可以充分利用计算机内存空间,实现灵活的内存动态管理。但是链表失去了数组随机读取的优点,同时链表由于增加了结点的指针域,空间开销比较大。链表最明显的好处就是,常规数组排列关联项目的方式可能不同于这些数据项目在记忆体或磁盘上顺序,数据的存取往往要在不同的排列顺序中转换。链表允许插入和移除表上任意位置上的节点,但是不允许随机存取。链表有很多种不同的类型:单向链表,双向链表以及循环链表。链表可以在多种编程语言中实现。像Lisp和Scheme这样的语言的内建数据类型中就包含了链表的存取和操作。程序语言或面向对象语言,如C,C++和Java依靠易变工具来生成链表。这些定义的内容可以在百度百科上收到,这里摘录说明一下。我们来讲单链表建立的具体过程。下面是我的代码,有详细的注释。头插法建立单链表 #include<stdio.h> #include<stdlib.h> typedef struct linklist { char data; struct linklist* next; }node, * link_list; link_list creatlist(link_list L) { link_list head = NULL;//初始化头结点 head = (node*)malloc(sizeof(node));//为头结点申请空间 node* p1, * p2; char data; head->next = NULL;//必须先头指针指向NULL,否则就是野指针。

    04

    算法与数据结构之三----循环链表

    /**************************************************************** 文件内容:线性表之循环链表操作 版本V1.0 说明:单链表必需从头结点开始遍历,而循环链表可以从任何地方都可以遍历,只不过只能想后遍历 循环链表的特点: 1.链表头指针和尾指针相接,也就是说没有头指针,也没有尾指针(也没有NULL指针,单链表尾指针为NULL) 2.从任何一个地方开始遍历都可以找到某一个节点X 创建方法: 方法1.先建立两个单链表,然后将一个单链表的头指针链接到另外一个单链表的尾指针。 方法2:在后插入法建立单链表的基础上,每创建一个节点,尾指针总是指向头指针。 判断一个链表是否是循环链表的方法: 对链表进行遍历,如果能找到某个指针域指向NULL,则为单链表,否则就是双链表 循环链表特性: 1.循环链表无法求长度,因为是无限长度的 2.循环链表是无法遍历完毕的,因为是无限长度的 3.循环链表插入,删除,查找跟单链表没有任何区别,只不过单链表有头指针,循环链表没有 头指针,或者说循环链表中任意一个节点指针都是头指针。 作者:HFL 时间:2013-12-25  *****************************************************************/  #include<stdio.h> #include<malloc.h> #include <windows.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif typedef struct CNode { INT32 data; struct CNode *next; }Cnode,*Linklist; /**************************************************************** 函数功能:创建一个循环链表,由单链表中初始化链表2(即尾部创建一个链表)派生而来                         输入参数:  无 返回值:链表的标头指针  说明:要引入一个新的指针变量,用于链接前后节点       在后插入建立单链表的基础上,每次创建一个节点,就将尾指针指向头指针 作者:HFL  时间:2013-12-24  ************T*****************************************************/  Linklist Creat_Clinklist() { Linklist L=NULL; Cnode *s; Cnode *probe =NULL; INT32 x;     scanf("%d",&x); while(x!=0) {  s=(struct CNode *)malloc(sizeof(Cnode));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); if(L== NULL) { L = s;  //第一个节点就必需保存投节点 } else { probe->next = s; //第二个节点开始,要引入一个临时指针,来暂存上一个节点地址,一遍链接前后两个节点 } probe = s;  //每次创建一个新节点,节点都必需重新移动。 s->data = x ; s->next = L; scanf("%d",&x); } } return L; } /*******************************************************

    01

    详解双向链表的基本操作(C语言)

    上一节学习了单向链表单链表详解。今天学习双链表。学习之前先对单向链表和双向链表做个回顾。 单向链表特点:   1.我们可以轻松的到达下一个节点, 但是回到前一个节点是很难的.   2.只能从头遍历到尾或者从尾遍历到头(一般从头到尾) 双向链表特点   1.每次在插入或删除某个节点时, 需要处理四个节点的引用, 而不是两个. 实现起来要困难一些   2.相对于单向链表, 必然占用内存空间更大一些.   3.既可以从头遍历到尾, 又可以从尾遍历到头 双向链表的定义:   双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。下图为双向链表的结构图。

    03

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券