C语言之链表的使用
C语言链表初学者都说很难,今天就来为大家讲讲链表
讲链表之前不得不介绍一下结构体,在链表学习之前大家都应该已经学了结构体,都知道结构体里面能有许多变量,每个变量可以当做这个结构体的属性,例如:
struct Stu{
char name[6];
int age;
};
在这里我们就定义了一个名为Stu的结构体,他有2个属性,name和age,在使用的时候我们先定义一个变量
struct Stu student;
通过 student.name 来获取 name属性的值。
这里的结构体只有2个东西,是不是和链表特别像?其实链表和结构体是一家人。
一个包含了指向自己指针的结构体就叫做链表。我把上面的结构体改成链表大家看看
struct Stu{
char name[6];
int age;
struct Stu * next;
};
这就是一个链表了,就是多了一个指针struct Stu * next; 为什么要加上这么一句它才是链表呢?
学习链表时大家都知道链表分为date 和 next 2个部分,date部分用来存放链表中的数据,这里又要说一点,date只是一个抽象的说法,date并不是一个变量,而是链表中存放的所有数据的总称,这里 name和age统称date部分。next 用来存放下一个数据块的地址,因为链表的类型是struct Stu ,那么指向下一个数据块地址的指针就必须是struct Stu * 类型的,所以这里要这么写 struct Stu * next; 当然了,不一定要叫next,但是习惯性还是用next这个名字,不然数据多了会用错。
定义好了大家就想使用了吧,不然我们花这么大力气去定义一个链表干嘛,那么如何使用链表呢?
1、定义一个链表的结构,如上面的例子
2、定义一个链表变量,struct Stu student
3、为新定义的链表student 分配空间
4、使用链表(增删改查)
要想使用一个链表要经历这么几个步骤,之前自学的时候愣是没有弄明白,结症就在这里。
首先我们要定义一个链表结构,因为只有这样,电脑才能知道我们要在链表中存入什么数据,然后就是定义一个新的链表了,但是定义完了却不能马上使用,因为你定义完了系统并没有为它分配空间,你要存一个数据,系统并不知道应该存到哪里,就好比你没有住的地方,但是你邀请一个人去你家做客,那个人能知道去哪里做客吗?所以接下来我们要为这个新的链表建一个家(分配一段内存),然后我们就可以对链表进行增删改查了。下面贴一段代码
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h> typedef struct Node01{
int i;
struct Node * pNext;
}Node,*pNode; pNode CreateNode(){
pNode p,ptail;
int len,i,k;
pNode q;
p = (pNode)malloc(sizeof(Node));
ptail = p;
ptail->pNext = NULL;
printf("请输入成绩数量:");
scanf("%d",&len);
for(i = 0;i<len;i++){ q=(pNode)malloc(sizeof(Node));
if(NULL==q){
printf("内存分配失败!");
return p;
}
printf("请输入第%d个成绩:",i+1);
scanf("%d",&k);
q->i = k;
ptail->pNext = q;
ptail = q;
ptail->pNext = NULL;
}
return p;
} int main(void){
pNode stuGrade,p;
stuGrade = CreateNode();
p = stuGrade->pNext;
free(stuGrade);
while(NULL!=p){
printf("%d ",*&*p);
p=p->pNext;
}
getch();
return 0;
}
这是一段可以 直接运行的代码,已经测试过。首先来介绍一下定义链表的结构吧,以免大家不明白。
这里用到了typedef,他的意思是定义一个新的类型,typedef + 类型结构 + 新名字
在这里我们用typedef定义了一个结构为
struct Node01{
int i;
struct Node * pNext;
}
的新变量Node以及一个指向这个变量的指针*Node。这样在后面的代码中我们就可以利用Node来代替struct Stu 这个名字了。比如定义一个新链表应该是struct Stu student,现在我们可以这样定义Node student 是不是很方便呢?
在定义了一个链表之后我们需要为新的链表分配空间,这是在CreatNode函数里面,通过malloc来分配内存,sizeof(Node)代表一个链表数据块的长度,也就是struct Stu的长度。malloc返回的类型应该是一个指针,并且是struct Stu类型的指针,所以前面要加上 struct Stu *也就是pNode。
了解了这些大家应该对指针有了更加深入的了解了吧~
C语言之链表的使用的更多相关文章
- C语言之链表
这两天在复习C语言的知识,为了给下个阶段学习OC做准备,以下的代码的编译运行环境是Xcode5.0版本,写篇博文把昨天复习的C语言有关链表的知识给大家分享一下,以下是小菜自己总结的内容,代码也是按照自 ...
- C语言习题 链表建立,插入,删除,输出
Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 222 Solved: 92 [Subm ...
- YTU 2430: C语言习题 链表建立,插入,删除,输出
2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec 内存限制: 128 MB 提交: 576 解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...
- 关于c语言单项链表尾添加
犹豫了几天,看了很多大牛写的关于c语言链表,感触很多,终于下定决心,把自己对于链表的理解随之附上,可用与否,自行裁夺.由于作者水平有限也是第一次写,不足之处,竭诚希望得到各位大神的批评指正.制作不易, ...
- C语言之链表list
#include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...
- C语言:链表实现的一个实例
问题:写一个程序输入你一年看过的所有电影以及每部电影的各种信息(简化问题:每部电影只要求输入片名和评价) 链表实现: #include<stdio.h> #include<stdli ...
- C语言单链表实现19个功能完全详解
谢谢Lee.Kevin分享了这篇文章 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将 ...
- (转)c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade { ...
- Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出
Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...
- c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. demo1 // lianbiao.cpp : Defines the entry point for the console app ...
随机推荐
- Clion pycharm激活码(可使用到2019年2月)
D87IQPUU3Q-eyJsaWNlbnNlSWQiOiJEODdJUVBVVTNRIiwibGljZW5zZWVOYW1lIjoiTnNzIEltIiwiYXNzaWduZWVOYW1lIjoiI ...
- php,单引号与双引号的区别
代码示例 <?php $s='666'; $s2="999"; $test = 'name{$s} - {$s2}'; $test2 = "name{$s} - { ...
- 1.2万事开头hello world+交互+getpass、sys模块初识
1.python的hello world: ①运行cmd-输入python-输入print (“hello world!”) ②创造.py的文本helloworld.py(后缀是为了告诉其他人)-输入 ...
- PMP:2.项目运行环境
事业环境因素(EEF):事业环境因素源于项目外部(往往是企业外部)的环境,是指项目团队不能控制的,将对项目产生影响.限制或指令作用的各种条件. 组织内部的事业环境因素: { uu组织文化.结构 ...
- ubuntu16.04下idea、webstorm等开发工具不能输入中文问题
问题: ubuntu16.04下idea.webstorm开发工具不能输入中文,就算切换到中文输入法输入的也是英文字母. 解决方案: 1.vim打开开发工具的启动文件(idea下就是idea.sh) ...
- shell脚本基础教程
一.什么是shell: shell解释:引用别人的话说:“Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁.Shell 既是一种命令语言,又是一种程序设计语言.” 简而言之, ...
- WPF常用样式总结
常用控件样式: <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation ...
- Cordova - 安装camera插件之后编译错误解决方法!
安装camera插件之后,编译出错,错误截图如下: 刚开始以为是AAPT编译导致的,尝试关闭AAPT编译选项,但是不行,认真看了一下编译出错信息,应该是缺少文件导致的,随后在对应的目录中加入了缺失的文 ...
- Linux源码编译安装程序
一.程序的组成部分 Linux下程序大都是由以下几部分组成: 二进制文件:也就是可以运行的程序文件 库文件:就是通常我们见到的lib目录下的文件 配置文件:这个不必多说,都知道 帮助文档:通常是我们在 ...
- Elastic-search在linux上的安装
今天是我装第四次 ES ,之前装好用了一段时间,后面莫名其妙爆炸了,炸出一堆异常... 安装环境: JDK1.8 centos ElasticSearch-6.2.4 jdk1.8以上,所以 ...