news 2026/7/5 17:21:25

算法讲解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/7/5 2:17:38

PySpark实战 - 2.2 利用Spark SQL计算总分与平均分

文章目录1. 实战概述2. 实战步骤3. 实战总结1. 实战概述 本次实战基于 Spark SQL 对 HDFS 上的学生成绩文本文件进行分析&#xff0c;通过 split 函数拆分姓名与各科成绩&#xff0c;利用嵌套查询和聚合计算&#xff0c;实现每位学生的总分与保留一位小数的平均分统计&#xf…

作者头像 李华
网站建设 2026/7/5 5:31:42

未来之窗昭和仙君(五十六)页面_预览模式——东方仙盟筑基期

未来之窗昭和仙君 - 一、功能概述此页面_预览模式功能用于将页面中的特定输入框转换为只读状态&#xff0c;呈现出预览模式。该功能支持对多种输入框类型进行处理&#xff0c;默认处理文本框、日期框和数字框&#xff0c;也可以自定义输入框类型。在处理时&#xff0c;会将输入…

作者头像 李华
网站建设 2026/7/4 4:03:27

第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第一赛季优化题--无人机配送

前言 “全球校园人工智能算法精英大赛”是江苏省人工智能学会举办的面向全球具有正式学籍的全日制高等院校及以上在校学生举办的算法竞赛。其中的算法巅峰赛属于产业命题赛道&#xff0c;这是第一赛季&#xff0c;对最后一道优化题进行浅浅地解读。 无人机配送 问题描述 低空…

作者头像 李华
网站建设 2026/7/5 6:05:42

CTF 大神才知道的 50 个解题骚套路,速速收藏!_ctf解题思路模板

CTF 大神才知道的 50 个解题骚套路&#xff0c;速速收藏&#xff01; CTF 竞赛的核心玩法 核心目标 &#xff1a; 以 Flag 为导向&#xff0c;光速拆解问题、熟练运用各种工具、培养模式化思维。 关键原则 &#xff1a; 先撒网再深挖&#xff08;信息收集要全面&#xff09;、…

作者头像 李华
网站建设 2026/7/1 22:26:42

白盒测试与代码覆盖率:从理论到实践的全方位解析

在软件开发的生命周期中&#xff0c;测试是确保产品质量的关键环节。白盒测试&#xff08;White-Box Testing&#xff09;&#xff0c;又称结构测试或玻璃盒测试&#xff0c;是一种基于程序内部逻辑和代码结构的测试方法。它与代码覆盖率&#xff08;Code Coverage&#xff09;…

作者头像 李华