C语言链表概述

链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构,是根据需要开辟内存单元。

链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。

链表中每一个元素称为“结点”,每个结点都应包括两个部分

  • 用户需要的实际数据。

  • 下一个结点的地址。

链表中各元素在内存中的地址可以是不连续的。

要找某一元素,必须先找到上一个元素,根据它提供的下一元素地址才能找到下一个元素。如果不提供“头指针”,则整个链表都无法访问。

链表如同一条铁链一样,一环扣一环,中间是不能断开的。

链表这种数据结构,必须利用指针变量才能实现,即一个结点中应包含一个指针变量,用它存放下一结点的地址。

C语言使用链表输出学号和成绩

#include//头文件
struct student //定义学生结构体
{int num; //学号 float score;//成绩 struct student *next;
};
int main()//主函数
{struct student str1,str2,str3;//定义结构体变量 struct student *head,*point;//定义结构体指针变量 str1.num=1;str1.score=90.8;str2.num=2;str2.score=90.0;str3.num=3;str3.score=85.0;head=&str1;//将第1个结点的起始地址赋给头指针headstr1.next=&str2;//将第2个结点的起始地址赋给第1个结点的next成员str2.next=&str3;//将第3个结点的起始地址赋给第2个结点的next成员 str3.next=NULL;//第3个结点的next成员赋给nullpoint=head;do{printf("%d %3.1f\n",point->num,point->score);//输出结果 point=point->next;}while(point!=NULL);return 0;//主函数返回值为0
}

编译运行结果:

1 90.8
2 90.0
3 85.0--------------------------------
Process exited after 0.1073 seconds with return value 0
请按任意键继续. . .

声明:

本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜。

C语言 | 链表概述相关推荐

  1. c语言链表中何时用点何时用箭头,链表基本操作及其过程详细叙述

    链表概述:链表是一种常见的数据结构.数组可以存放数据,但是使用数组时要先指定数组中包含元素的个数,即数组长度.但是如果向这个数组中加入的元素个数超过了数组的大小时,便不能将内容完全保存.例如在定义一个 ...

  2. c语言链表ppt,C语言链表及链表上机题.ppt

    C语言链表及链表上机题 第13讲 链表 链表概述(1) 所谓链表是指若干个数据项(每个数据项称为一个"结点")按一定的原则连接起来.每个数据项都包含有若干个数据和一个指向下一个数据 ...

  3. OpenCL™(开放计算语言)概述

    OpenCL™(开放计算语言)概述 异构系统并行编程的开准 OpenCL™(开放计算语言)是一种开放的.免版税的标准,用于对超级计算机.云服务器.个人计算机.移动设备和嵌入式平台中的,各种加速器进行跨 ...

  4. [转载 整理]C语言链表实例

    C语言链表有单链表.双向链表.循环链表.单链表由数据域和指针域组成,数据域存放数据,指针域存放该数据类型的指针便于找到下一个节点.双链表则含有头指针域.数据域和尾指针域,域单链表不同,双链表可以从后一 ...

  5. C 语言链表其他实现

    C 语言链表其他实现 #include<stdio.h> #include<stdlib.h> #define N 10typedef struct list{int data ...

  6. C 语言 链表的创建与打印

    C 语言 链表的创建与打印 /* 包含的头文件 */#include <stdio.h>#include <stdlib.h>/* 定义一个表示链表的结构体指针 */struc ...

  7. C语言链表返回第n个到最后的节点的算法(附完整源码)

    C语言链表返回第n个到最后的节点的算法 C语言链表返回第n个到最后的节点的算法完整源码(定义,实现,main函数测试) C语言链表返回第n个到最后的节点的算法完整源码(定义,实现,main函数测试) ...

  8. C语言链表返回具有的回文序列的算法(附完整源码)

    C语言链表返回具有的回文序列的算法 C语言链表返回具有的回文序列的算法完整源码(定义,实现,main函数测试) C语言链表返回具有的回文序列的算法完整源码(定义,实现,main函数测试) #inclu ...

  9. C语言链表是否为循环表的算法(附完整源码)

    C语言链表是否为循环表的算法 C语言链表是否为循环表的算法完整源码(定义,实现,main函数测试) C语言链表是否为循环表的算法完整源码(定义,实现,main函数测试) #include <io ...

最新文章

  1. 饥荒海难机器人怎么用_饥荒:海难是一款野外生存游戏
  2. Zabbix JMX之tomcat监控
  3. 《软件测试技术实战:设计、工具及管理》—第2章 2.2节运用决策表设计测试用例...
  4. tcp/udp socket编程异同
  5. Ajax系列之三:UpdatePanel
  6. UGUI_使用DoTween
  7. oracle时间类型插入,oracle 插入时间字符串 Date类型
  8. 安装多实例造成***S故障
  9. 使用eclipse遇到的unable to install breakpoint的问题
  10. c/c++标准库中的文件操作总结
  11. day10 多进程、多线程(一)
  12. Feign 集成 Hystrix实现不同的调用接口不同的设置
  13. windows7 C盘清理(尽量做到最全,手把手教,狗看完都说它会)
  14. 17分钟过桥,过桥最短时间问题
  15. 计算机中应用g,CH340g使用说明详解 - 全文
  16. MySQL索引(最左匹配查询规则)
  17. 【八股文】4 Spring
  18. 魔百盒CM211-2系列(ZG/CH/YS)海思MV300H/310芯片-刷机固件及教程
  19. gensim安装教程
  20. 计算机网络通信技术的应用领域,基于计算机远程网络通信技术的应用分析

热门文章

  1. Spring Data Redis:Sentinel的高可用性
  2. 在Jersey测试中模拟SecurityContext
  3. 使用Payara Micro的Easy Java EE Microservices
  4. [EBOOK]十大Java性能问题
  5. OpenShift上的无痛集装箱化JBoss通用贷款处理
  6. 将Java EE Monolith雕刻成微服务
  7. 无论是否使用Spring Framework,为什么我们会失败?
  8. appengine_Google AppEngine:任务队列API
  9. 拜托,Java。 最终是否支持多行字符串文字
  10. 存根类 测试代码 java_嘲弄和存根–了解Mockito的测试双打