news 2026/6/26 17:58:16

算法讲解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/26 2:30:10

儿童生长曲线分析技术深度解析:原理、实现与预警机制

本文从技术视角深入探讨儿童身高体重管理的核心挑战,详细解析生长曲线分析的原理、标准化数据来源及百分位/Z-score计算方法。并以长高乐APP为例通过Python代码示例展示数据模型设计、API接口实现与可视化技术,并系统阐述基于生长曲线的5大预警机制,为儿童健康管理提供技术支…

作者头像 李华
网站建设 2026/6/25 9:02:56

为什么越来越多的网工运维转行网络安全?

为什么越来越多的网工运维转行网络安全&#xff1f; 、 最近越来越多的网工运维小伙伴都在吐槽&#xff1a;干网工、运维多年&#xff0c;薪资还是5.6K&#xff0c;技术也遇瓶颈上不去&#xff0c;考虑转岗或者转行。其中大部分的网工运维小伙伴们纷纷瞄准了高薪高前景的网络…

作者头像 李华
网站建设 2026/6/25 21:20:30

社交网络数据质量治理:经验与教训

社交网络数据质量治理&#xff1a;从踩坑到进阶的实战经验 一、引言&#xff1a;社交网络的“数据烂尾楼”困境 钩子&#xff1a;你遇到过这些“反人类”社交体验吗&#xff1f; 刷到完全不感兴趣的推荐&#xff1f;比如你是健身达人&#xff0c;却总收到美妆广告&#xff1…

作者头像 李华
网站建设 2026/6/24 6:38:10

std::greater结构体用在sort和lower_bound

https://cn.bing.com/search?pglt417&qgreater%3Cstring%3E std::sort(numbers, numbers 5, std::greater<int>());&#xff0c;std::greater{}也可以 #if _LIBCPP_STD_VER > 14 template <class _Tp void> #else template <class _Tp> #endif s…

作者头像 李华
网站建设 2026/6/25 18:45:32

当数字员工搭载AI销冠系统,如何迅速提升销售效率?

数字员工通过引入AI销冠系统&#xff0c;能够显著优化业务流程&#xff0c;降低企业运营成本&#xff0c;并提升整体效率。数字员工的智能化特性使其能够自动化处理大量客户交互&#xff0c;如电话回访和信息收集&#xff0c;减少了对传统人工客服的依赖。这不仅提高了工作效率…

作者头像 李华