0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言入门之链表概述

jf_78858299 来源:C语言入门到精通 作者:闫小林 2023-03-24 15:04 次阅读

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个结点的起始地址赋给头指针head
str1.next=&str2;//将第2个结点的起始地址赋给第1个结点的next成员
str2.next=&str3;//将第3个结点的起始地址赋给第2个结点的next成员
str3.next=NULL;//第3个结点的next成员赋给null
point=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
请按任意键继续. . .
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内存
    +关注

    关注

    8

    文章

    2767

    浏览量

    72774
  • 数据结构
    +关注

    关注

    3

    文章

    564

    浏览量

    39900
收藏 人收藏

    评论

    相关推荐

    C语言链表知识点(2)

    C语言链表知识点(2)
    发表于 08-22 10:38 181次阅读
    C<b class='flag-5'>语言</b><b class='flag-5'>链表</b>知识点(2)

    C语言单向链表

    本帖最后由 snowmay001 于 2016-5-22 15:57 编辑 lianbiao.cpp/* 练习使用链表:创建链表、遍历链表、查找节点、添加节点、删除节点*/#include
    发表于 05-22 15:53

    C语言链表的学习

    链表有有头链表和无头链表无头链表:所有的节点都包含了有效数据。有头链表:用一个固定的头节点来指代整个链表
    发表于 08-21 13:12

    C语言链表

    C语言链表,,,
    发表于 11-07 17:19

    C语言玩转链表

    C语言是必学的一个课程,不管你是单片机还是嵌入式物联网,都是基础,所以还是要好好学习的今天推荐的资料是关于C语言链表的资料我自己看了一下主要
    发表于 11-13 13:50

    玩转C语言链表-链表各类操作详解

      链表概述  链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构。它可以根据需要开辟内存单元。链表有一个“头指针”变量,以head表示,它存放一个地址。该地址指向一个元
    发表于 09-18 13:30

    C语言概述

    上海电机学院第1章_C语言概述第一章本章要点C语言的特点C程序的结构在计算机上运行
    发表于 09-01 06:41

    怎么实现c语言循环链表

    怎么实现c语言循环链表
    发表于 10-19 06:07

    概述C语言的特点

    的资源,得到更多的信息,对软件工具的发展起到了更大的促进作用。1、嵌入式Linux C语言开发概述C语言的特点:
    发表于 11-04 07:21

    如何在C语言中去创建一种双向链表

    双向链表的结构是由哪些部分组成的?如何在C语言中去创建一种双向链表呢?
    发表于 12-24 06:22

    请问链表在单片机C语言中有应用吗?

    链表在单片机C语言中有应用么?
    发表于 10-16 07:28

    C语言链表的作用是什么?

    C语言中指针用的很少,链表、文件操作几乎没用过,所以也不能理解到底有什么作用。各位有经常在做程序时会用到这些吗。
    发表于 11-06 06:23

    C语言链表相关资料下载

    C语言链表相关资料
    发表于 03-08 10:47 5次下载

    C语言入门教程之堆栈的详细资料概述

    本文档的主要内容详细介绍的是C语言入门教程之堆栈的详细资料概述
    发表于 11-29 11:47 11次下载

    C语言_链表总结

    本篇文章介绍C语言链表相关知识点,涉及链表的创建、单向链表、循环链表、双向链表、单向循环
    的头像 发表于 08-14 09:53 1483次阅读