《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂

《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂

🔥小叶-duck个人主页

❄️个人专栏《Data-Structure-Learning》

《C++入门到进阶&自我学习过程记录》

《算法题讲解指南》--优选算法

《算法题讲解指南》--递归、搜索与回溯算法

未择之路,不须回头
已择之路,纵是荆棘遍野,亦作花海遨游


目录

3.反转链表

题目链接:

题目描述:

题目示例:

解法(递归):

算法思路:

C++算法代码:

算法总结及流程解析:

4.两两交换链表中的节点

题目链接:

题目描述:

题目示例:

解法(递归):

算法思路:

C++算法代码:

算法总结及流程解析:

5.快速幂

题目链接:

题目描述:

题目示例:

解法(递归-快速幂):

算法思路:

C++算法代码:

算法总结及流程解析:

结束语


3.反转链表

题目链接:

206. 反转链表 - 力扣(LeetCode)

题目描述:

题目示例:

解法(递归):

算法思路:

      1.递归函数的含义交给你一个链表的头指针,你帮我逆序之后,返回逆序后的头结点
      2.函数体:先把当前结点之后的链表逆序,逆序完之后,把当前结点添加到逆序后的链表后面即可
      3.递归出口:当前结点为空或者当前只有一个结点的时候不用逆序,直接返回
      注意注意注意:链表的题一定要画图,搞清楚指针的操作

C++算法代码:

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* reverseList(ListNode* head) { //递归的结束条件:当递归到头节点为空结点或者只要一个结点则返回 if(head == nullptr || head->next == nullptr) { return head; } ListNode* newhead = reverseList(head->next); head->next->next = head; //head->next相当于是反转后的尾结点 head->next = nullptr; return newhead; } };

算法总结及流程解析:

4.两两交换链表中的节点

题目链接:

24. 两两交换链表中的节点 - 力扣(LeetCode)

题目描述:

题目示例:

解法(递归):

算法思路:

      1.递归函数的含义:交给你一个链表,将这个链表两两交换一下,然后返回交换后的头结点;
      2.函数体:先去处理一下第二个结点往后的链表,然后再把当前的两个结点交换一下连接上后面处理后的链表;
      3.递归出口当前结点为空或者当前只有一个结点的时候,不用交换,直接返回
      注意注意注意:链表的题一定要画图,搞清楚指针的操作!

这道题其实在我们的优选算法中已经讲解过了,只是当时是利用其链表的性质使用循环、迭代(模拟算法)来解决的,感兴趣的可以去看看。

《算法题讲解指南:优选算法-链表》--51.两数相加,52.两两交换链表中的节点-ZEEKLOG博客

但是我相信如果真的理解了用宏观的视角来看待递归,一定会觉得递归比上面的模拟实现简单太多了。

C++算法代码:

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* swapPairs(ListNode* head) { //解法:递归算法(宏观视角看待递归) //递归结束条件:当此时子问题中的链表节点只有一个或者没有为空 if(head == nullptr || head->next == nullptr) { return head; } ListNode* tmp = swapPairs(head->next->next); ListNode* newhead = head->next; newhead->next = head; head->next = tmp; return newhead; } };

算法总结及流程解析:

5.快速幂

题目链接:

50. Pow(x, n) - 力扣(LeetCode)

题目描述:

题目示例:

解法(递归-快速幂):

算法思路:

      1.递归函数的含义求出 x 的 n 次方是多少,然后返回
      2.函数体先求出 x 的 n/2 次方是多少,然后根据 n 的奇偶得出 x 的 n 次方是多少
      3.递归出口:当 n 为 0 的时候,返回 1 即可。

C++算法代码:

class Solution { public: double Pow(double x, long long n) //因为n为负数时可以取到-2^32,当转成-n时则超出int最大值,需要改成long long类型 { if(n == 0) { return 1; } double tmp = myPow(x, n / 2); return n % 2 == 0 ? tmp * tmp : tmp * tmp * x; } double myPow(double x, int n) { double ret = n < 0 ? Pow(x, -(long long)n) : Pow(x, n); if(n < 0) { ret = 1 / ret; } return ret; } };

算法总结及流程解析:

结束语

      到此,3.反转链表,4.两两交换链表中的节点,5.快速幂 这三道算法题就讲解完了。反转链表:通过递归逆序后续链表,再将当前节点接在尾部;两两交换链表节点:递归处理后续链表后交换当前两个节点;快速幂:利用分治思想递归计算x的n次方。希望大家能有所收获!

Read more

Trae x Vizro:低代码构建专业数据可视化仪表板的高效方案

Trae x Vizro:低代码构建专业数据可视化仪表板的高效方案

声明:文章为本人真实测评博客,非广告,并没有推广该平台 ,为用户体验文章 目录 * 前言 * 一.核心工具与优势解析 * 低代码高效开发 * 专业视觉设计 * 高度灵活可定制 * AI赋能创新 * 二.操作步骤:从安装到生成效果 * 第一步. 获取MCP配置代码 * 第二步:下载 * 第三步:在 Trae 中导入 MCP 配置并建立连接 * 三. 实战:用Vizro MCP快速构建仪表板 * 1. 提出需求 * 2.智能体生成代码 * 3.查看运行结果 * 4.优化与部署 * 四.Vizro MCP核心功能解析 * get_vizro_chart_or_dashboard_plan * get_model_json_

By Ne0inhk
Rokid 手势识别技术深度解析:解锁 AR 无接触交互的核心秘密

Rokid 手势识别技术深度解析:解锁 AR 无接触交互的核心秘密

引言 在聊手势识别前,咱们先搞清楚:Rokid是谁?它为啥能把AR手势做得这么自然? Rokid是国内AR(增强现实)领域的“老兵”了,从2014年成立就盯着一个目标——让AR走进日常。你可能见过它的产品:能戴在脸上的“AR眼镜”Max Pro、能揣在兜里的“AR主机”Station 2、适合专业场景的“Station Pro”,这些设备不是用来“炫技”的,而是想让咱们摆脱手机、手柄的束缚,直接用手“摸”虚拟东西。 而手势识别,就是Rokid给AR设备装的“最自然的遥控器”——比如调大虚拟屏幕像捏橡皮一样捏合手指,翻页像翻书一样挥手。但不同设备、不同开发需求,需要搭配不同版本的SDK(软件开发工具包),这就像“不同型号的手机要装对应版本的APP”。 一、基础认知:先选对版本,避免开发走弯路 Rokid手势识别技术随SDK版本迭代持续优化,不同版本适配的Unity(开发工具)

By Ne0inhk
打造你的家庭 AI 助手(三):QQ 机器人接入你的 OpenClaw

打造你的家庭 AI 助手(三):QQ 机器人接入你的 OpenClaw

不得不承认腾讯进步的速度太快了,几条命令就可以接入Openclaw,也不用设置IP白名单了,在 QQ开放平台还增加了专门的Openclaw入口: 没啥好说的,很简单,安装完Openclaw之后,执行如下命令(命令也是生成好的): openclaw plugins install @tencent-connect/openclaw-qqbot@latest openclaw channels add--channel qqbot --token"" openclaw gateway restart 以下内容已经过时了,留作纪念 以下内容已经过时了,留作纪念 以下内容已经过时了,留作纪念 ⚠️ 重要提示:如果是家用宽带,没有申请固定 IP 地址的话,大可以放弃这种方式。由于 QQ 开发平台的白名单限制,机器人会非常不稳定,频繁掉线。建议使用云服务器或有固定 IP 的环境部署。 前言 在完成 OpenClaw 安装后,

By Ne0inhk
OpenClaw配置Bot接入飞书机器人+Kimi2.5

OpenClaw配置Bot接入飞书机器人+Kimi2.5

上一篇文章写了Ubuntu_24.04下安装OpenClaw的过程,这篇文档记录一下接入飞书机器+Kimi2.5。 准备工作 飞书 创建飞书机器人 访问飞书开放平台:https://open.feishu.cn/app,点击创建应用: 填写应用名称和描述后就直接创建: 复制App ID 和 App Secret 创建成功后,在“凭证与基础信息”中找到 App ID 和 App Secret,把这2个信息复制记录下来,后面需要配置到openclaw中 配置权限 点击【权限管理】→【开通权限】 或使用【批量导入/导出权限】,选择导入,输入以下内容,如下图 点击【下一步,确认新增权限】即可开通所需要的权限。 配置事件与回调 说明:这一步的配置需要先讲AppId和AppSecret配置到openclaw成功之后再设置订阅方式,

By Ne0inhk