使用C++按给定大小将链表分组反转

使用c++按给定大小将链表分组反转

在本文中,我们处理一个单链表,任务是以 k 为一组反转该列表。例如 –

Input: 1->2->3->4->5->6->7->8->NULL, K = 3Output: 3->2->1->6->5->4->8->7->NULLInput: 1->2->3->4->5->6->7->8->NULL, K = 5Output: 5->4->3->2->1->8

对于这个问题,想到的一种方法是尾随列表并在子列表的大小达到 k 并继续时反转列表。

寻找解决方案的方法

通过这种方法,我们通常会遍历列表并保留一个计数器来计算子列表中的元素数量。当计数器达到 k 的计数时,我们反转该部分。

示例

#include using namespace std;class Node {   public:   int data;   Node* next;};Node* reverse(Node* head, int k) {   if (!head)      return NULL;   Node* curr = head;   Node* next = NULL;   Node* prev = NULL;   int count = 0;   while (curr != NULL && count next;      curr->next = prev;      prev = curr;      curr = next;      count++;   }   if (next != NULL) // if our link list has not ended we call reverse function again      head->next = reverse(next, k);   return prev;}void push(Node** head_ref, int new_data) { // function for pushing data in the list   Node* new_node = new Node();   new_node->data = new_data;   new_node->next = (*head_ref);   (*head_ref) = new_node;}void printList(Node* node) { // function to print linked list   while (node != NULL) {      cout <data <next;   }   cout << "n";}int main() {   Node* head = NULL;   int k = 3; // the given k   push(&head, 8);   push(&head, 7);   push(&head, 6);   push(&head, 5);   push(&head, 4);   push(&head, 3);   push(&head, 2);   push(&head, 1);   cout << "Original list n";   printList(head);   head = reverse(head, k); // this function will return us our new head   cout << "New list n";   printList(head);   return (0);}

输出

Original list1 2 3 4 5 6 7 8New list3 2 1 6 5 4 8 7

上述方法的时间复杂度为O(N),其中N是给定列表的大小,并且该方法适用于递归。这种方法也适用于更高的约束。

立即学习“C++免费学习笔记(深入)”;

上述代码的解释

我们将在这种方法中遍历数组并不断反转它,直到我们的计数器变量小于 k 。当计数器达到 k 的值时,我们调用另一个反转函数将该子列表的最后一个节点连接到下一个反转子列表的第一个节点。这是通过递归完成的。

结论

在本文中,我们解决了使用递归按给定大小的组反转链表的问题。我们还学习了解决此问题的 C++ 程序以及解决此问题的完整方法(Normal)。我们可以用其他语言比如C、java、python等语言来编写同样的程序。我们希望这篇文章对您有所帮助。

以上就是使用C++按给定大小将链表分组反转的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445385.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:28:22
下一篇 2025年12月17日 22:03:17

相关推荐

  • 在C语言中,将二叉树的右视图打印出来

    任务是打印给定二叉树的右节点。首先用户将插入数据以创建二叉树,然后打印所形成的树的右视图。 上图展示了使用节点10、42、93、14、35、96、57和88创建的二叉树,其中选择并显示在树的右侧的节点。例如,10、93、57和88是二叉树的最右节点。 示例 Input : 10 42 93 14 3…

    2025年12月17日
    000
  • 在C语言中,什么是简单断言?

    断言是一个语句,用于肯定地声明当到达该行代码时事实必须为真。 断言对于获取满足的预期条件很有用。 > 简单断言 简单断言可以通过assert(表达式)方法实现,该方法位于assert.h头文件中。 简单断言的语法如下 – 立即学习“C语言免费学习笔记(深入)”; assert(ex…

    2025年12月17日
    000
  • 匿名联合体和结构体在C语言中的应用

    这里我们来看看什么是C语言中的匿名联合体和结构体。匿名联合体和结构体就是未命名的联合体和结构体。由于它们没有名称,因此我们无法创建它的直接对象。我们将其用作嵌套结构或联合。 这些是匿名联合和结构的示例。 struct { datatype variable; …};union { datatyp…

    2025年12月17日
    000
  • 在C/C++中,我们可以有多少级指针?

    实际上,C程序中常见的是一到两个静态级别的指针。三级间接很少见。但是无限指针间接非常常见。可以通过结构体的帮助实现无限指针间接。 struct list { struct list *next; … } lst; lst->next->next->next->…-&g…

    2025年12月17日
    000
  • 在C语言中,kbhit指的是检测键盘是否有输入的函数

    在这里,我们将看到 C 中的 kbhit 功能。kbhit 基本上是键盘敲击。该函数位于 conio.h 头文件中。因此,为了使用它,我们必须将此头文件包含到我们的代码中。 kbhit() 的功能是,当按下某个键时,它返回非零值,否则返回零。 示例 #include #include main() …

    2025年12月17日
    000
  • 使用递归方法在C++中找到链表倒数第n个节点

    给定一个单链表和正整数 N 作为输入。目标是使用递归找到给定列表中从末尾算起的第 N 个节点。如果输入列表有节点 a → b → c → d → e → f 并且 N 为 4,那么倒数第 4 个节点将是 c。 我们将首先遍历直到列表中的最后一个节点以及从递归(回溯)增量计数返回时。当 count 等…

    2025年12月17日
    000
  • 解释C语言中的单体和模块化编程

    下面详细解释了单体编程和模块化编程之间的区别以及优缺点。 单体编程 如果我们在一个函数中编写整个程序,即在主函数中,那么我们称之为单体编程。但是,在一个函数中编写整个逻辑不是一个好的编程风格。 缺点 单体编程的缺点包括: 程序看起来非常庞大和复杂。调试、测试和维护程序非常困难。 模块化编程 如果将程…

    2025年12月17日
    000
  • C++程序以三角形形式打印乘法表

    要以表格或图形形式记住一些基本乘法结果,请使用乘法表。本文将介绍如何用 C++ 生成一个看起来像直角三角形的乘法表。在少数可以轻松记住大量结果的情况下,三角形表示法是有效的。在这种格式中,表格逐行、逐列显示,每行仅包含填充该列的条目。 为了解决这个问题,我们需要 C++ 中的基本循环语句。为了以三角…

    2025年12月17日
    000
  • 如何在C语言中编写自己的头文件?

    在C语言中编写自己的头文件的步骤 − 输入代码并将其保存为“sub.h”。编写一个名为“subtraction.c”的主程序,其中 −包含新的头文件。使用“sub.h”代替sub.h头文件中的所有函数现在都可以使用。直接调用函数sub()。“subtraction.c”和“sub.h”应该在同一个文…

    2025年12月17日
    000
  • C语言的限制

    问题 与其他编程语言相比,C语言有哪些限制? 解决方案 C语言阻止或禁止了面向对象编程语言的概念,如继承、多态、封装和数据抽象。 C编程语言不会对每行代码进行错误检测,它会在完成整个编码后检查错误。 它不具备命名空间属性。 立即学习“C语言免费学习笔记(深入)”; C编程在数据抽象方面的水平不足,即…

    2025年12月17日
    000
  • 在C程序中,字符串的字母数字缩写是什么?

    在这里,我们将看到一个与给定字符串的字母数字缩写相关的有趣问题。字符串长度小于10。我们将打印出所有的字母数字缩写。 字母数字缩写是由字符和数字混合形成的。该数字的值是被省略的字符数。可能有任意数量的被省略的子字符串。没有两个子字符串是相邻的。让我们看一下获取这个概念的算法。 算法 printAbb…

    2025年12月17日
    000
  • 在C语言中,结构体中的可变数组成员

    C 结构中的灵活数组成员意味着我们可以在结构中声明没有维度的数组,并且其大小本质上是灵活的。灵活数组成员必须是类的最后一个成员。 下面是一个示例: 示例 #include#include#include//structure of type employee and must contain at …

    2025年12月17日 好文分享
    000
  • 如何在C中实现自己的sizeof

    要使用sizeof(),我们可以使用变量x获取值,使用&x,它将打印出其地址。现在,如果我们增加&x的值,它可能以不同的方式增加。如果只增加一个字节,那就意味着它是字符类型,如果增加的值是4,那就是int或float类型,依此类推。因此,通过计算&x + 1和&x之间…

    2025年12月17日
    000
  • 使用C++编写一个程序,找到由奇数数字组成的第N个数字

    C++有一个巨大的函数列表来解决数学问题。其中一个数学函数是使用代码找到第N个奇数位数。本文将描述找到奇数位数的完整方法,并理解奇数是什么以及由奇数位数组成的数字是什么。 找到由奇数位数组成的第N个数字 奇数在除以2时会有余数,所以前几个奇数是1、3、5、7、9、11、13、15、17、19&#82…

    2025年12月17日
    000
  • 在C语言中打印对称的双三角形图案

    给定行数,程序必须以最小的复杂性打印对称双三角形图案。 示例 Input: 5Output: X X O X O X X O X O X X O X O X X 整个问题包含3个不同的分区 − 立即学习“C语言免费学习笔记(深入)”; 对于奇数n,打印上半部分的n-1行,对于偶数n,打印上半部分的n…

    2025年12月17日
    000
  • 解释C语言中逻辑运算符和赋值运算符的概念

    首先,让我们学习一下逻辑运算符。 逻辑运算符 这些用于逻辑上组合两个(或更多)表达式。 它们是逻辑与(&&)、逻辑或(||)和逻辑非(!) 逻辑与(&&) 立即学习“C语言免费学习笔记(深入)”; exp1 exp2 exp1&&exp2 TTTTFF…

    2025年12月17日
    000
  • 提交C++作业

    在本教程中,我们必须编写一个算法来找到一种在不被监考人员发现的情况下通过作业的方法。每个学生都必须向监考人员提交作业。学生 A 的作业是交给学生 B 的,因此学生 B 必须在监考人员注意到的情况下将作业返回/传递给学生 A。 所有学生都坐在队列中。我们需要找到一种方法将作业传回给学生A而不被抓住。他…

    2025年12月17日
    000
  • 获取和设置C语言中线程属性的堆栈大小

    要在C中获取和设置线程属性的堆栈大小,我们使用以下线程属性: pthread_attr_getstacksize() 用于获取线程堆栈大小。stacksize属性给出了分配给线程堆栈的最小堆栈大小。如果成功运行,则返回0,否则返回任何值。 它接受两个参数: pthread_attr_getstack…

    2025年12月17日
    000
  • 在C程序中,将以下内容翻译为中文:查找链表倒数第n个节点的程序

    给定 n 个节点,任务是打印链表末尾的第 n 个节点。程序不得更改列表中节点的顺序,而应仅打印链表最后一个节点中的第 n 个节点。 示例 Input -: 10 20 30 40 50 60 N=3Output -: 40 在上面的例子中,从第一个节点开始,遍历到 count-n 个节点,即 10,…

    2025年12月17日
    000
  • C语言编写的汉诺塔程序

    汉诺塔是一个数学难题。它由三根杆和若干个不同大小的圆盘组成,这些圆盘可以滑动到任意一根杆上。难题以圆盘按大小升序整齐堆叠在一根杆上开始,最小的圆盘在顶部。我们必须将相同的堆叠移到第三根杆上。 难题的目标是将整个堆叠移动到另一根杆上,遵守以下简单规则− 一次只能移动一个圆盘。 每次移动包括从一根堆中取…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信