news 2026/6/15 10:59:51

算法讲解7:递归

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法讲解7:递归

递归:在数学与计算机中是指在函数的定义中只用函数自身的方法,在计算机科学中还额外指一种通过重复将问题分解为同类的子问题而解决问题的方法

1.递归出口(边界条件):找全递归终止条件

2.注意:写代码只考虑当前问题怎么解决,不分析下层问题怎么展开,不用去倒明白,就能处理当前就行

3.理解:画图,构思,找规律

4.例题:

题目描述

面试题 08.06. 汉诺塔问题

在经典汉诺塔问题中,有 3 根柱子及 N 个不同大小的穿孔圆盘,盘子可以滑入任意一根柱子。一开始,所有盘子自上而下按升序依次套在第一根柱子上(即每一个盘子只能放在更大的盘子上面)。移动圆盘时受到以下限制:
(1) 每次只能移动一个盘子;
(2) 盘子只能从柱子顶端滑出移到下一根柱子;
(3) 盘子只能叠在比它大的盘子上。

请编写程序,用栈将所有盘子从第一根柱子移到最后一根柱子。
你需要原地修改栈。

示例 1:
输入:A = [2, 1, 0],B = [],C = []
输出:C = [2, 1, 0]

第一步,先简化题意,就是把1柱的盘子移动到3柱,以2柱为媒介,归根到底,还是先放大盘子,但是1柱先动的是小盘子,所以通过媒介把小盘子放到下面,实现“让大盘子能比小盘子先动”,

第二步:那么这种题肯定无法用循环解决,我们用栈来充当柱子,再编写“根据不同请况盘子不同移动”的逻辑,我们需要一个函数,在调用的时候传入123三柱的栈,

那麽我们就知道一共需要做3个事情,设盘子数量aa,s起点,e终点,h媒介

1.把x-1个盘子通过媒介传到柱子,s->e->h

2.处理最后一个,s->e

3.把前面x-1个盘子移回正轨,h->s->e

代码

package 博客; import java.util.Stack; import java.util.Scanner; public class 递归 { public static void hannuota(int aa, Stack<Integer> s, Stack<Integer> e, Stack<Integer> h) //s起点,e终点,h媒介 { if(aa==1)//这是减到底了,写这个if的目的是里面可以放return { int p=s.pop(); e.add(p); return ; } hannuota(aa-1,s,h,e);//1,把aa-1个都处理,这一行就是只处理一次,处理完后调用自身,就是持续调用aa-1次 int d=s.pop();//2 处理最后一个,后面每一次都会运行这个,决定不同的是输入的值 e.add(d); hannuota(aa-1,h,e,s);//3 必须在最后,把前面的aa-1个放回正轨 } public static void main(String[] args) { Stack<Integer> a = new Stack<>(); Stack<Integer> b = new Stack<>(); Stack<Integer> c = new Stack<>(); Scanner sc=new Scanner(System.in); int n=sc.nextInt(); for(int i=0;i<n;i++) { a.add(sc.nextInt()); } int aa=a.size(); hannuota(aa,a,c,b); System.out.println(c.toString()); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:23:45

灰盒测试在软件开发中的关键应用场景与价值探索

1 灰盒测试的核心定位与价值 灰盒测试作为介于黑盒测试与白盒测试之间的重要测试方法&#xff0c;既关注外部功能表现&#xff0c;又结合内部结构知识进行验证。其核心价值在于突破传统测试方法的局限&#xff1a;通过有限度的代码逻辑知晓&#xff08;如API接口结构、数据库表…

作者头像 李华
网站建设 2026/6/15 14:37:09

保姆级教程:大模型学习指南(零基础入门到项目实战),建议收藏_AI大模型神仙级入门教程(非常详细)

这篇文章为AI大模型初学者提供全面入门指南&#xff0c;包括理解大模型基础、准备软硬件环境、学习机器学习与深度学习知识、使用预训练模型、进行模型微调以及参与实战项目。文章详细介绍了从初阶应用到模型训练再到商业闭环的学习路径&#xff0c;帮助读者系统掌握大模型技术…

作者头像 李华
网站建设 2026/6/15 9:15:47

CTF网络安全大赛介绍

赛事介绍 CTF竞赛模式分为以下三类&#xff1a; 一、解题模式&#xff08;Jeopardy&#xff09;在解题模式CTF赛制中&#xff0c;参赛队伍可以通过互联网或者现场网络参与&#xff0c;这种模式的CTF竞赛与ACM编程竞赛、信息学奥赛比较类似&#xff0c;以解决网络安全技术挑战题…

作者头像 李华
网站建设 2026/6/15 14:38:37

备赛四--

1.在 JavaScript 中&#xff0c; sort() 是数组的内置方法&#xff0c;用于对数组元素进行排序&#xff0c;默认按字符串的 Unicode 编码排序&#xff0c;所以对数字、对象排序时需要自定义比较函数&#xff0c;这也是我们代码里用到的核心逻辑。一、 sort() 基础用法1. 默认…

作者头像 李华
网站建设 2026/6/13 19:28:12

Flask-SocketIO 连接超时问题排查与解决(WSL / 虚拟机场景)

问题关键词&#xff1a;Flask-SocketIO、ConnectionError、127.0.0.1、WSL、Socket.IO、连接超时 适用场景&#xff1a;WSL / 虚拟机 / Docker 中运行客户端&#xff0c;宿主机运行服务端一、问题背景 在开发 LLM 任务型对话 Agent 时&#xff0c;我使用了 Flask Flask-Socket…

作者头像 李华