首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用C语言编写反向链表程序

反向链表是指将链表中的节点顺序颠倒,即原链表的头节点变为尾节点,原链表的尾节点变为头节点。下面是用C语言编写反向链表程序的示例代码:

代码语言:c
复制
#include <stdio.h>
#include <stdlib.h>

// 定义链表节点结构体
typedef struct Node {
    int data;
    struct Node* next;
} Node;

// 反向链表函数
Node* reverseLinkedList(Node* head) {
    Node* prev = NULL;
    Node* curr = head;
    Node* next = NULL;

    while (curr != NULL) {
        next = curr->next;
        curr->next = prev;
        prev = curr;
        curr = next;
    }

    return prev;
}

// 打印链表函数
void printLinkedList(Node* head) {
    Node* curr = head;

    while (curr != NULL) {
        printf("%d ", curr->data);
        curr = curr->next;
    }

    printf("\n");
}

int main() {
    // 创建链表
    Node* head = (Node*)malloc(sizeof(Node));
    Node* second = (Node*)malloc(sizeof(Node));
    Node* third = (Node*)malloc(sizeof(Node));

    head->data = 1;
    head->next = second;

    second->data = 2;
    second->next = third;

    third->data = 3;
    third->next = NULL;

    printf("原链表:");
    printLinkedList(head);

    // 反向链表
    Node* newHead = reverseLinkedList(head);

    printf("反向链表:");
    printLinkedList(newHead);

    return 0;
}

上述代码中,我们首先定义了一个链表节点结构体 Node,包含一个整型数据 data 和一个指向下一个节点的指针 next。然后,我们实现了一个 reverseLinkedList 函数,用于反向链表。该函数使用三个指针 prevcurrnext,通过遍历链表将节点的 next 指针指向前一个节点,从而实现链表的反向。最后,我们在 main 函数中创建了一个简单的链表,并调用 reverseLinkedList 函数进行反向操作,然后通过 printLinkedList 函数打印原链表和反向链表的内容。

这个程序的应用场景是在需要对链表进行反向操作时使用。例如,在某些算法或数据结构中,需要按照相反的顺序遍历链表,或者需要将链表的顺序进行逆转等。

腾讯云提供了丰富的云计算产品,其中与链表相关的产品可能没有直接的对应。但是,腾讯云提供了强大的计算、存储和网络服务,可以用于支持开发和部署链表相关的应用。具体可以参考腾讯云的官方网站(https://cloud.tencent.com/)获取更多信息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • c语言流水灯程序详细讲解,c语言编写单片机流水灯程序详解

    C语言编写的单片机流水灯程序 一、硬件电路 因为电路单片机控制,所以电路非常简洁。其电路原理图见下图,印制板图如下图所示。 ?...源程序如下(为了便于讲解,我们为每行程序加上了编号): 程序各行作用如下: 00行:把AT89C2051的头文件“AT89x051.H”包含进来。...不过请注意,这里没有象上期的程序一样,把表示函数开始的“{”单独成行,而是把下一行写在一起了。事实上,写C程序的时候,可以把多行写作一行,C编译器只要遇到分号就认为是一行语句的结束。...当然,我们不能因为C程序有这个特点,就随意把多行合作一行书写,实际书写C程序的时候,还是要养成良好的程序书写习惯,按照约定俗成的原则来书写。 03行:声明for()循环。...)”,并把刚才输入的C程序加入到工程中。

    2.7K20

    C语言建个单向链表

    链表是和数据结构相挂钩的,现在可以先认识一下哦,不一定非要弄懂,但是弄懂也没毛病 。学习链表之前要把结构体弄懂哦,还有指针等。基础是一定要打牢的,不然以后学数据结构会很困难的。...任务描述 建立一个带头结点的单向链表。 相关知识 什么是链表链表和二叉树是C语言数据结构的基础和核心。...单链表 单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始,链表是使用指针进行构造的列表,又称为结点列表,因为链表是由一个个结点组装起来的,其中每个结点都有指针成员变量指向列表中的下一个结点...简单单向链表的图示: ?...链表是结构、指针相结合的一种应用,它是由头、中间、尾多个链环组成的单方向可伸缩的链表,链表上的链环我们称之为结点; 每个结点的数据可用一个结构体表示,该结构体由两部分成员组成:数据成员与结构指针变量成员

    1.2K60

    C语言学习教程,C语言编写扫雷游戏

    本文实例为大家分享了C语言实现扫雷游戏及其优化的具体代码,供大家参考,具体内容如下 关于扫雷优化 1.核心思想:使用两个二维数组进行设计,一个用于显示,一个用于后台雷的布置。...3.界面布局仍需要进行优化 虽然说C语言开发发展前景好,但易学难精。由于入门容易这也导致了市场上人员泛滥、人才稀缺的局面产生。但是在互联网越来越强烈的竞争下,这样的人也最终会被市场淘汰。...对于想要从事C语言行业的小伙伴来说,一定要清楚自己未来的职业规划和就业方向。 扫雷游戏代码 相关运行样例 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多关注支持。

    7.7K20

    Unix 是 C 语言编写的吗?

    Unix 与 C 语言的关系 ? Unix 确实是 C 语言编写的,而且是世界上第一个 C 语言编写的操作系统。但是 Unix 是怎么产生的?C 语言又是怎么产生的?...Unix 为什么要用 C 语言编写?相信看完这篇文章你很快就会有了答案。...可是 NB 还是有很多的问题,于是 Dennis Ritchie 就又发明了 C 语言,最终在 1974年,Ken Thompson 和 Dennis Ritchie 一起 C 语言重新编写了第四版的...C 语言解决了 B 语言的很多缺陷,并很快成为了开发操作系统最流行的一种编程语言。新版本的 Unix 以及今天很多类 Unix 的操作系统都是 C 语言开发出来的。...好了,讲到这里,我想大家都清楚了 Unix 和 C 语言是怎么来的了,以及为什么要用 C 语言编写 Unix。

    4.8K40

    C语言-链表(单向链表、双向链表)

    链表的每个节点就是一个结构体变量,节点里有一个或者两个指针,可以保存上一个节点和下一个节点的地址,方便遍历链表,删除、插入节点时定位位置。 2....案例: 单向链表的创建与使用 下面例子采用函数封装的形式编写,每个功能都使用子函数实现。...实现的功能如下: 初始化链表头 插入节点的函数(链表任意位置插入,链表尾插入) 删除节点的函数(链表任意位置删除、链表尾删除) 遍历链表,输出链表里的所有信息 #include #include...案例: 创建双向链表循环,实现插入、删除、遍历 双向链表在每个节点里新增加了一个指针,用于保存上一个节点的地址,现在的节点里一个两个指针,一个保存上一个节点的地址,一个保存下一个节点的地址。...反向遍历*/ next_p=head; while(next_p->prev!

    2.1K30

    C语言链表实例--玩转链表

    结点之间的联系可以指针实现 例如:每一次分配一块空间可用来存放一个学生的数据,我们可称之为一个结点。有多少个学生就应该申请分配多少块内存空间,也就是说要建立多少个结点。...可编写一个建立链表的函数 creat。...这里 TYPE 表示 struct stu, LEN表示 sizeof(struct stu)主要的目的是为了在以下程序内减少书写并使阅读更加方便。...结构stu 定义为外部类型,程序中的各个函数均可使用该定义。 creat 函数用于建立一个有 n 个结点的链表,它是一个指针函数,它返回的指针指向 stu结构。...下方为创客专门针对C语言链表分析的视频资料,对链表感兴趣的可以看看学习下 1 C语言玩转链表 http://www.makeru.com.cn/live/1392_338.html?

    2K31

    C语言链表实例--玩转链表

    结点之间的联系可以指针实现   例如:每一次分配一块空间可用来存放一个学生的数据,我们可称之为一个结点。有多少个学生就应该申请分配多少块内存空间,也就是说要建立多少个结点。   ...可编写一个建立链表的函数 creat。...程序如下:   #define NULL 0   #define TYPE struct stu   #define LEN sizeof (struct stu)   struct stu //定义结点结构...这里 TYPE 表示 struct stu, LEN表示 sizeof(struct stu)主要的目的是为了在以下程序内减少书写并使阅读更加方便。...结构stu 定义为外部类型,程序中的各个函数均可使用该定义。   creat 函数用于建立一个有 n 个结点的链表,它是一个指针函数,它返回的指针指向 stu结构。

    1.6K20

    c语言编写图书管理系统程序_C语言图书管理系统

    DOS界面的图书管理系统,具体内容如下 程序分为两块:管理员操作(收录图书、删除图书等)和会员操作(注册、借书、还书等); 1、管理员操作界面 2、会员操作界面 global.h头文件:(程序中只使用了一个编写的头文件...20]; while(1){ infile >> n >> s >> num >> l >> c; //从文件导入信息,并注册会员信息 Member_Add(n,num,l,c); if(infile.eof...; Member_Record++; } /*会员注册程序*/ void Member_Reg() { string n,c[20],choice[2]; cout << “\t\t\t\t会员注册...总结 以上是编程之家为你收集整理的C语言图书管理系统简洁版全部内容,希望文章能够帮你解决C语言图书管理系统简洁版所遇到的程序开发问题。...如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。 本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

    1.9K20

    C语言 | 链表概述

    C语言链表概述 链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构,是根据需要开辟内存单元。 链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。...如果不提供“头指针”,则整个链表都无法访问。 链表如同一条铁链一样,一环扣一环,中间是不能断开的。...C语言使用链表输出学号和成绩 #include//头文件 struct student //定义学生结构体 {   int num; //学号   float score;//成绩   ...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线    C语言开发工具 VC6.0、Devc++、VS2019使用教程...100道C语言源码案例请去公众号:C语言入门到精通

    1.4K30

    9.4 C语言链表

    01链表 1、链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构,是根据需要开辟内存单元。 2、链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。...3、链表中每一个元素称为“结点”,每个结点都应包括两个部分 (1)用户需要的实际数据。 (2)下一个结点的地址。 4、链表中各元素在内存中的地址可以是不连续的。...如果不提供“头指针”,则整个链表都无法访问。 6、链表如同一条铁链一样,一环扣一环,中间是不能断开的。...7、链表这种数据结构,必须利用指针变量才能实现,即一个结点中应包含一个指针变量,用它存放下一结点的地址。 C语言 | 将一个二维数组行列元素互换 更多案例可以go公众号:C语言入门到精通

    1.3K2725

    C语言 | 简单链表

    “要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例42:C语言实现一个简单链表,它由3个学生数据的结点组成,要求输出各结点中的数据。 解题思路:读者在学习这道例题的时候,应该首先分析三个问题。 各个结点是怎么样构成链表的?...int num; //学号 float score;//成绩 struct student *next; }; int main()//主函数 { struct student a,b,c;...next成员 b.next=&c;//将第3个结点的起始地址赋给第2个结点的next成员 c.next=NULL;//第3个结点的next成员赋给null point=head; do

    1.9K2119

    C语言创建链表

    一、链表中结点的存储        链表的结点左边一部分是存放的数据,右边一部分是后继指针指向下一个结点的地址。...C语言中通常定义一个结构体类型来存储一个结点,如下: struct node { int data; struce node *next; //下一个结点的类型也是struct node...,所以后继指针的类型也必须是struct node * }; 二、让我们把结点连起来吧        想要把结点一个个串起来,还需要三个struct node *类型的指针:head(头指针,指向链表的开始...,方便从头遍历整个链表)、p(临时指针,指向那些还未连接的结点)、q(当前指针,指向当前最新串入的结点)。   ...当链表还没有建立时,头指针head为空。 struct node *head; head=NULL; //头指针初始为空   现在我们来创建第一个结点,并用临时指针p指向这个结点。

    1.7K20

    C语言编写交换数组数值的代码教程

    使用C语言编程的一个常见需求是交换数组中两个元素的值。这个操作在很多算法和程序中都有应用,因此学会如何编写交换数组数值的代码是非常重要的。本教程将向大家介绍如何使用C语言实现这个功能。...下面是交换数组元素值的代码示例:4C语言编写交换数组数值的代码教程#includevoid swap(int *a, int *b) {int temp = *a;*a = *b;*b = temp;...运行这段代码,我们可以看到输出结果如下:交换前的数组:4 2 6 1 8交换后的数组:1 2 6 4 8通过这个简单的例子,我们学会了如何使用C语言编写交换数组元素值的代码。...泛型编程是一种编程方法,它允许我们编写与具体类型无关的代码。在C语言中,我们可以使用`void`指针来实现泛型编程。...总结一下,本教程向大家介绍了如何使用C语言编写交换数组元素值的代码。我们首先使用一个辅助变量来实现交换,然后使用泛型编程的方法使交换函数适用于不同类型的数组。

    18820
    领券