<返回更多

如何建立一个动态链表?原来就这么简单!

2020-08-11    
加入收藏

什么是链表?当你用一个数组存放数据时就需要给它定义一个长度,如果定一个未知的数据,你就需要扩大数组的范围,有时如果由于某种特殊原因,数据增加,有需要重新修改程序,扩大数组的存储范围,链表就是一种更加简便,不受限制的存储方式,只需要根据分配内存单元即可存储的方式结构。

处理链表需要哪些函数?

C提供了一些内存管理函数这些内存管理函数就可以为你分配内存空间。

如何建立一个动态链表?原来就这么简单!
  1. malloc()函数
  2. calloc()函数
  3. free()函数
  4. reallo()函数
如何建立一个动态链表?原来就这么简单!

在执行程序的过程中先一个一个开辟结点然后在每一个结点中输入数据。由于程序是为了实现某一功能而设计的程序所以下面我将举例来说明如何建立动态链表?

举一个建立n个整数的单链表的例子,由于本人能力有限,不过建立一个动态链表还是很容易的。

如何建立一个动态链表?原来就这么简单!

建立一个n个整数的单链表,我用两个函数来实现分别是creatlist函数和printlist函数,它们的功能一个是创建,一个是输出。

首先定义一个结构体的类型,这个结构体类型包括一个整形成员和一个指向结构体类型的指针成员。然后我们在输出函数中设三个指针变量,头指针,指向当前节点的指针和指向当前节点的前一个节点的指针。

如何建立一个动态链表?原来就这么简单!

第一,用malloc()函数分配第一个结点,用head指向该结点,然后用r指向该结点。

第二,继续用malloc()函数做第一个结点,s指向新结点,向s输出数据,然后用r的next指向s,r再指向s。

第三,重复操作,一直创建到第n个整数型的单链表为止。再用printlist函数输出。就好啦!

如何建立一个动态链表?原来就这么简单!

具体代码如下:

struct node

{

int date;

struct node*next;

};

struct node*creatlist(into n)

{

struct node*head ,*s,*r;

int i=0;

if((head=strucr node*)malloc(sizeof(struct node)))==NULL)

{

printf("error!");

return 0;

}

head_>next=NULL;

r=head;

for(i=1;i<n;i++)

{

if((s=(struct node*)malloc(sizeof(struct node)))==NULL)

}

}

如何建立一个动态链表?原来就这么简单!

希望看完的你动动小手点个关注,你的点赞就是对我最大的鼓励。

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>