首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

c语言 | 链表实现

今天分享的是链表。准确的说,链表不算是C语言中的内容,而是属于数据结构的内容,因为它没有新的知识点,只是利用了结构体和指针等的知识。...但是它在C语言中应用还是很广泛的,在RTOS中,也是非常多的地方使用到了链表。今天暂时说一下链表实现和简单应用,下一节当中再介绍双链表。 首先,要对链表有个概念。...链表其实是对数组的扩展,数组是为了存储很多个数据而产生的,但是它有两个缺陷,第一个缺陷就是数组里面所有的元素都是同样的类型,为了解决这个问题,产生了结构体。...说明:在本次实验中,使用的是vscode编辑器,编译环境是gcc,不建议使用VC6.0,因为VC6.0使用的c语言标准太老了,很多语法都不支持,并且,VC6.0使用体验极差,没有代码高亮功能等等。...节点的插入可以是从头部插入,也可以是从尾部插入,一般不会从中间插入,没有意义,因为插入主要是扩展链表的,没有理由从中间插入

2K30

C语言实现链表

文章目录 链表常规操作 定义链表结构体 构造链表 头插法实现 尾插法实现 链表的头尾插法详解 链表判空 计算链表长度 遍历链表 链表头、尾插法构造效果 链表指定位置插入结点 链表指定位置删除结点...) }*LinkList, Node; 构造链表 头插法实现 /* * 头插法创建链表(带头结点) * datas 接收数组,用于赋值链表的结点数据 * len datas数组的长度,便于遍历...链表指定位置插入结点 代码实现 /* * 链表指定位置插入结点 * list 链表 * data 要插入的结点的数据 * pos 结点插入的位置(逻辑位置(1,2,3,...)) */...代码实现 /* * 链表指定位置删除结点 * list 链表 * *val 用来存储删除结点的数据 * pos 结点删除的位置(逻辑位置(1,2,3,...)) */ int DeleteNode...():5 Travel():2 4 8 6 12 源代码 源代码已上传到 GitHub Data-Structure-of-C,欢迎大家下载 C语言实现数据结构

1.9K41
您找到你想要的搜索结果了吗?
是的
没有找到

C语言实现链表逆置

学完C语言你会发现真的不难,可能就指针有点绕,其余的都是小打小闹。链表是数据结构里的内容,数据结构和算法是程序设计的核心,也是学IT这行必须掌握的内容。...如下此题其实还有别的方法,比如用数组存储链表中的数据,需要注意的是数组小标要准确. 任务描述 本关需要你设计一个程序,实现链表的逆置。...链表的逆置有两种方法:头插法和就地逆置法,这两种方法虽然都有逆置的效果,但还是有着不小的差别。...头插法 逆置链表初始为空,表中节点从原链表中依次“删除”,再逐个插入逆置链表的表头(即“头插”到逆置链表中),使它成为逆置链表的“新”的第一个结点,如此循环,直至原链表为空。...就地逆置法 先假定有一个函数,可以将以head为头结点的链表逆序,并返回新的头结点。

2.9K30

C语言实现链表-增删改查

链表是由一连串节点组成的数据结构,每个节点包含一个数据值和一个指向下一个节点的指针。链表可以在头部和尾部插入和删除节点,因此可以在任何地方插入和删除节点,从而使其变得灵活和易于实现。...链表通常用于实现有序集合,例如队列和双向链表链表的优点是可以快速随机访问节点,而缺点是插入和删除操作相对慢一些,因为需要移动节点。...下面是一套封装好的链表框架,包括创建链表插入节点、删除节点、修改节点、遍历节点和清空链表等常见操作,其中每个节点存储一个结构体变量,该结构体中包含一个名为data的int类型成员。..., int data) { ListNode *node = createNode(data); node->next = head; return node; } // 在链表尾部插入一个新节点...接着定义了用于创建新节点、插入节点、删除节点、修改节点、遍历节点和清空链表等操作的子函数,并在main函数中演示了这些操作的使用例子。在使用完链表后一定要调用clearList函数释放内存空间。

33720

链表链表-增-删-查(C语言)

free(*pphead); //这时候第一个数据就是之前第二个数据了 *pphead = ppheadNext; } 查找 下面的删除和插入都要在先在链表中找到为前提。...void SLTInsert(SLTNode** pphead,SLTNode* pos, SLTDataType x) { //如果在第一个结点前插入数据 //那就是头插,直接调用头插的函数...SLTPushFront(pphead,x); } else { //创建一个新结点来存放新的数据 SLTNode* newnode = SLTCreat(x); //要在pos前面插入...SLTNode*pos) { //当删除第一个结点的时候,无法找到他的前一个结点 if (pos == *pphead) { SLTPopFront(pphead); } else { //链表每次老是要寻找前一个结点...SLTNode*pos) { //当删除第一个结点的时候,无法找到他的前一个结点 if (pos == *pphead) { SLTPopFront(pphead); } else { //链表每次老是要寻找前一个结点

68920

C语言链表实现以及链表的介绍

一、为什么会存在链表 因为我们常用的顺序表会存在以下的一些问题: 1. 中间/头部的插入删除,时间复杂度为O(N) 2. 增容需要申请新空间,拷贝数据,释放旧空间。会有不小的消耗。 3....例如当前容量为100,满了以后增容到 200,我们再继续插入了5个数据,后面没有数据插入了,那么就浪费了95个数据空间。 针对以上顺序表中存在的问题,有人就设计出了链表这一结构。...下面我将就链表中结构最简单的链表做一个详细的介绍。...二、链表的介绍 2.1链表的概念和结构 概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表 中的指针链接次序实现的 。...2.2链表的分类 1.单向或双向 2.带头或不带头 3.循环或非循环 虽然有这么多的链表的结构,但是我们实际中最常用还是两种结构: 三、链表实现 见以下代码: #pragma once #include

6610

C语言——T链表专题

二、链表实现 typedef int SLTDataType; typedef struct SListNode { SLTDataType data; //节点数据 struct SListNode...void SLTInsertAfter(SLTNode* pos, SLTDataType x); //删除pos之后的节点 void SLTEraseAfter(SLTNode* pos); //销毁链表...void SListDesTroy(SLTNode** pphead); 三、链表的分类 虽然有这么多的链表的结构,但是我们实际中最常⽤还是两种结构:链表和双向带头循环链表 1、⽆头单向⾮循环链表...2、带头双向循环链表:结构最复杂,⼀般⽤在单独存储数据。实际中使⽤的链表数据结构,都 是带头双向循环链表。...另外这个结构虽然结构复杂,但是使⽤代码实现以后会发现结构会带 来很多优势,实现反⽽简单了,后⾯我们代码实现了就知道了。

5610

单向循环链表-链表链表)的基本操作及C语言实现

n个结点通过指针域相互链接,组成一个链表。   图3 含有n个结点的链表   图 3 中,由于每个结点中只包含一个指针域,生成的链表又被称为线性链表链表。   ...图 4 头结点、头指针和首元结点   链表中可以没有头结点,但是不能没有头指针!   链表的创建和遍历万事开头难,初始化链表首先要做的就是创建链表的头结点或者首元结点。...i=1; inext; } //创建插入结点c link * c=(link*)malloc(sizeof(link)); c->elem=elem; //向链表插入结点 c->next=temp...->next; temp->next=c; return p; }   注意:首先要保证插入位置的可行性,例如图 5 中单向循环链表,原本只有 5 个结点,插入位置可选择的范围为:1-6,如果超过6,...=1; inext; } //创建插入结点c link * c=(link*)malloc(sizeof(link)); c->elem=elem; //向链表插入结点 c->next=temp->next

76530

C语言链表实现18个功能完全详解

*/ /* 4.检查链表是否为空,若为空则返回1,否则返回0 */ /* 5.返回单链表中第pos个结点中的元素,若pos超出范围,则停止程序运行*/ /* 6.遍历一个链表*/ /* 7.从链表中查找具有给定值...x的第一个元素,若查找成功则返回该结点data域的存储地址,否则返回NULL */ /* 8.把链表中第pos个结点的值修改为x的值,若修改成功返回1,否则返回0 */ /* 9.向链表的表头插入一个元素...*/ /* 10.向链表的末尾添加一个元素*/ /* 11.向链表中第pos个结点位置插入元素为x的结点,若插入成功返回1,否则返回0 */ /* 12.向有序链表插入元素x结点,使得插入后仍然有序...if(pos == i){ p->data = x; return 1; }else{ return 0; } } /* 9.向链表的表头插入一个元素...1 */ } /* 12.向有序链表插入元素x结点,使得插入后仍然有序*/ void insertOrderList(struct sNode* *hl, elemType x) { /*

1.3K40

C语言链表实现

我学数据结构的时候也是感觉很困难,当我学完后我发现了之所以困难时因为我没有系统的进行学习,而且很多教授都只是注重数据结构思想,而忽略了代码方面,为此我写了这些博文给那些试图自学数据结构的朋友,希望你们少走弯路 我尝试用最简单的语言与代码来描述链表...,事实上它本身也很简单 静态链表实现 下面一部分的讨论都将围绕上面这幅图片展开,既然是逐步实现,我不考虑在开头就让这个链表完美实现,它将只有两个部分:链表的创建&遍历链表输出 首先我们要知道一些简单的概念...这个疑问你可以自己解答比较好 动态链表实现 到这里一个简单的链表就已经实现了,但是我们还需要继续改进,因为我们有时候不知道每个节点储存的数据,所以我们就需要一个动态链表了,下面这个将实现把用户输入的数据以链式结构储存...; node *tail=c; a->data=9; a->next=b; a->pre=NULL; b->data=17; b->next=c; b->pre=a; c->data...,我没有制作图片,所以这需要读者认真去思考一下,建议画图,也很容易理解,下面代码是在上面创建了abc的基础上实现的在ab间插入一个k,然后再删除它 //插入 node *k=new node; k

5.4K30
领券