C语言实现单链表

单链表的应用非常广,它可以实现栈,队列等;

Problem

我对学习任何东西都希望能找到尽可能简单的例子,而不是看起来好高大上的;

对链表这样简答的数据结构,有些书也是写得太过“完美”啦;

初学者很难抓住重点,反正我初学的时候就是看不懂;

因此我打算从简单入手去演示;

我们需要实现下面图这样的结构,叫做链表哈;

Solution

首先咱们要想到这几个ABC圆圈可以代表一个数据的节点,什么是节点呢?;

节点就好比是几个同学聚集到一个宿舍一样,他们各自有各自的身高体重;

因此,我们需要一个结构体,声明如下:

struct node {
    int height;
    int weight;

};

这样一个结构体似乎还差些什么,我们观察上面的图发现,在每个圆圈的外边还有一个连接线;

我们需要这样一条线;

因此,我们的代码可能会是这样的:

struct node {
    int height;
    int weight;
    void * a_line;

};

但是呢!再想想,我们这条线指向的是和它本身一样的结构体;

我们如果声明为和它一样的指针不是更好吗?

struct node {
    int height;
    int weight;
    struct node * a_line;

};

我们把代码改回来,这样的声明到底合不合法呢?事实上,这里的递归声明一个指针是合法的;

好节点声明完啦,我们可以测试链表啦!这有点不可思议,那么简单吗?看看main函数;

#include <stdio.h>
#include <stdlib.h>

struct node {
    int hight;
    int weight;
    struct node * a_line;

};

int main(void)
{
    struct node * A = (struct node*)malloc(sizeof(struct node));
    A->weight = 60; //kg
    A->hight =  170;    //cm
    A->a_line = NULL;
    return 0;
}

好啦!链表完成啦!你或许以为我在开玩笑呢!好吧,其实的确是一个简单的链表啦;

只不过,它只有一个A点,你无法接受这种一个节点的链表,好吧,我们把ABC连接起来;

首先,我们需要三个点;

int main(void)
{
    struct node * A = (struct node*)malloc(sizeof(struct node));
    A->weight = 60; //kg
    A->hight =  170;    //cm
    A->a_line = NULL;

    struct node * B = (struct node*)malloc(sizeof(struct node));
    B->weight = 50; //kg
    B->hight =  160;    //cm
    B->a_line = NULL;

    struct node * C = (struct node*)malloc(sizeof(struct node));
    C->weight = 70; //kg
    C->hight =  180;    //cm
    C->a_line = NULL;

    return 0;
}

然后,是把他们连接起来;

    A->a_line = B;
    B->a_line = C;

好啦!连起来啦,满意啦吧!,你肯定以为我又骗你;

毕竟,怎么也看不出来连接起来啦;

好,让我们从A到C路线走一程,看看能不能走通;

struct node * we;
    we = A;
    while (we != NULL){
        printf("The hight is %d and the weight is %d \n",we->hight,we->weight);
        we = we->a_line;
    }       

为了,”旅行“我们把名字报道到了旅行社;

并且,我们获取到了第一站地址就是A的地址啦!

出发;

while循环的意思很简单,判断我们是否到达终点;

没有到达就是打印,xxx,,你懂的;

然后we = we->a_line这句话是关键哦!

我不想解释,自己画图想想!!!

想好了看看我们的运行结果吧!

Discussion

我们的简单链表已经完成,它的缺点太多啦!

让我给你数数吧!例如:

1,要是数据很多怎么办,100000个节点,这个main函数得写多长啊。。。

2,这个连接的方式也太土啦吧!万一某个节点忘记连接下一个怎么办。。。

3,要是我想知道这个节点到底有多长,难道每次都要从头到尾数一遍嘛。。。

4,要是我想在尾部添加一个节点,是不是爬也要爬到尾部去啊。。。

等等。。。

我会尽快给大家写另一个版本哈!

See Also

http://www.cprogramming.com/tutorial/c/lesson15.html

时间: 2024-10-08 20:14:06

C语言实现单链表的相关文章

C语言实现单链表节点的删除(带头结点)

我在之前一篇博客<C语言实现单链表节点的删除(不带头结点)>中具体实现了怎样在一个不带头结点的单链表的删除一个节点,在这一篇博客中我改成了带头结点的单链表.代码演示样例上传至 https://github.com/chenyufeng1991/DeleteLinkedList_HeadNode.删除类型有两种: (1)删除某个位置pos的节点: (2)推断x值是否在链表中,若存在则删除该节点: 核心代码例如以下: //删除某个位置pos的节点 Node *DeletePosNode(Node

C语言实现单链表的节点插入(带头结点)

我在之前一篇博客<C语言实现单链表(不带头结点)节点的插入>中具体实现了怎样在一个不带头结点的单链表中进行节点的插入.可是在实际应用中,带头结点的链表更为经常使用.更为方便.今天我们就要来使用带头结点的单链表进行节点的插入.演示样例代码上传至 https://github.com/chenyufeng1991/InsertList_HeadNode  . 核心代码例如以下: Node *InsertNode(Node *pNode,int pos,int x){ int i = 0; Node

C语言实现单链表(带头结点)的基本操作

我在之前一篇博客<C语言实现单链表(不带头结点)的基本操作>中具体实现了不带头结点的单链表的11种操作:如计算链表长度.初始化.创建链表.清空链表等等.但是在实际使用中,带头结点的单链表往往比不带头结点的单链表用的更多,使用也更为方便.因为不用单独考虑第一个节点的情况了,第一个节点和其他后续节点的处理全都一样了,简化操作.这篇博客将会来实现带头结点的单链表的11种操作.代码上传至: https://github.com/chenyufeng1991/LinkedList_HeadNode  .

C语言实现单链表-03版

在C语言实现单链表-02版中我们只是简单的更新一下链表的组织方式: 它没有更多的更新功能,因此我们这个版本将要完成如下功能: Problem 1,搜索相关节点: 2,前插节点: 3,后追加节点: 4,一个专门遍历数据的功能: Solution 我们的数据结构体定义如下,和上一个版本稍微有所不同: 例如,我们把人这个结构体添加一个name域,前几个版本没有名字的节点: 我们叫起来很尴尬,都是第几个第几个节点,好啦!现在有名字啦! #include <stdio.h> #include <s

C语言实现单链表-02版

我们在C语言实现单链表-01版中实现的链表非常简单: 但是它对于理解单链表是非常有帮助的,至少我就是这样认为的: 简单的不能再简单的东西没那么实用,所以我们接下来要大规模的修改啦: Problem 1,要是数据很多怎么办,100000个节点,这个main函数得写多长啊... 2,这个连接的方式也太土啦吧!万一某个节点忘记连接下一个怎么办... 3,要是我想知道这个节点到底有多长,难道每次都要从头到尾数一遍嘛... 4,要是我想在尾部添加一个节点,是不是爬也要爬到尾部去啊... 这个是简单版中提出

「C语言」单链表/双向链表的建立/遍历/插入/删除

最近临近期末的C语言课程设计比平时练习作业一下难了不止一个档次,第一次接触到了C语言的框架开发,了解了View(界面层).Service(业务逻辑层).Persistence(持久化层)的分离和耦合,一种面向过程的MVC的感觉. 而这一切的基础就在于对链表的创建.删除.输出.写入文件.从文件读出...... 本篇文章在于巩固链表的基础知识(整理自<C语言程序设计教程--人民邮电出版社>第十章),只对链表的概念及增删改查作出探讨,欢迎指教. 一.链表结构和静态/动态链表 二.单链表的建立与遍历

【c语言】 单链表

单链表,顾名思义是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素. 链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据. 我们在这里使用C语言实现: .h 文件: #pragma once #include<assert.h> #include <malloc.h> typedef int DataType; typedef struct SLis

C语言实现单链表(不带头结点)节点的插入

对单链表进行增删改查是最主要的操作.我在上一篇博客<C语言实现链表节点的删除>实现了删除单链表中的某个节点. 这里我们要来实如今某个位置插入节点.演示样例代码上传至https://github.com/chenyufeng1991/InsertList  . 核心代码例如以下: Node *InsertToPosition(Node *pNode,int pos,int x){ if (pos < 0 || pos > sizeList(pNode) ) { printf(&quo

一起talk C栗子吧(第十三回:C语言实例--单链表二)

各位看官们,大家好,从今天开始,我们讲大型章回体科技小说 :C栗子,也就是C语言实例.闲话休提, 言归正转.让我们一起talk C栗子吧! 看官们,上一回中咱们说的是链表以及单链表顺序储存方式的例子,这一回咱们继续说单链表的例子,不 过这一回咱们说的是:单链表链式存储. 看官们单链表的链式存储,咱们在上一回已经说过,这里就不再多说了.这一回主要举例子,通过例子来 说明什么是单链表的链式存储. 通过对比单链表的顺序储存和链式存储,可以看出来. 顺序存储链表的优点:遍历链表方便,查找也方便. 顺序存

一起talk C栗子吧(第十二回:C语言实例--单链表一)

各位看官们,大家好,从今天开始,我们讲大型章回体科技小说 :C栗子,也就是C语言实例.闲话休提, 言归正转.让我们一起talk C栗子吧! 看官们,上一回中咱们没有说具体的例子,而且是说了例子中的文件组织结构.这一回咱们继续说C例子, 说的例子是链表,更准确的说法叫作单链表.咱们不但要说C例子,而且会在例子中使用上一回中说过的 文件组织结构,就当作是举例说明文件组织结构的使用方法. 有点一石二鸟的感觉,哈哈. 链表定义 看官们,所谓的链表其实就是一组元素通过一定的方式链接在一起.比如我们坐的火车