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 ...
随机推荐
- php memcache 基础操作
<?php/** * Memcache缓存操作 * @author hxm * @version 1.0 * @since 2015.05.04 */class MCache extends O ...
- Codeforces Round #547 (Div. 3) F 贪心 + 离散化
https://codeforces.com/contest/1141/problem/F2 题意 一个大小为n的数组a[],问最多有多少个不相交的区间和相等 题解 离散化用值来做,贪心选择较前的区间 ...
- mysql data type <----> java data type (数值)
https://dev.mysql.com/doc/refman/5.7/en/storage-requirements.html +----------------------------+---- ...
- 向jsp中引入公共文件
前沿,在网页开发中,总会存在某几个.js或者某几个.css是所有.jsp文件的公用文件,为了方便引用 我们把这些在公共的.js及.css文件放到一个.jsp文件中,只需要将这个引入所有公共.js及.c ...
- verilog HDL-并行语句之assign
线网型数据对象: 是verilog hdl常用数据对象之一,起到电路节点之间的互联作用,类似于电路板上的导线. wire是verilog hdl默认的线网型数据对象. 线网型数据对象的读操作在代码任何 ...
- BASH 环境
本节内容 1. 什么是shell 2. 命令的优先级 3. 元字符 4. 登录shell与非登录shell 一 什么是shell shell一般代表两个层面的意思,一个是命令解释器,如bas ...
- UITableView自动计算cell高度并缓存
原文链接:http://www.jianshu.com/p/64f0e1557562 cell高度计算的历史 在iOS8之前,如果UITableViewCell的高度是动态的,如果想要显示正确的话,我 ...
- win7安装vs2017时闪退
最近用公司的笔记本电脑,装win10发现太卡,无奈最终选择安装win7系统,本以为系统安装成功了,接下来只要安装下开发环境:vs2017 sqlserver等就好,结果在安装vs2017的时候,一直出 ...
- Linux Ubuntu部署web环境及项目tomcat+jdk+mysql
1,下载文件 在官网下载好 tomcat.jdk.mysql的linux压缩包 后缀名为.tar.gz 并通过xftp上传到服务器 或者直接通过linux命令 下在wget文件的下载地址 例如: wg ...
- String的substring方法
string.substring(beginIndex, endIndex) 左闭右开. 测试 public static void main(String[] args) { String a = ...