• 2024-07-22(算法)汉诺塔————<递归>
    1.题⽬链接:329.矩阵中的最⻓递增路径 2.题⽬描述:3.解法(暴搜->记忆化搜索):算法思路:这是⼀道递归⽅法的经典题⽬,我们可以先从最简单的情况考虑:•假设n=1,只有⼀个盘⼦,很简单,直接把它从A中拿出来,移到C上;•如果n=2呢?这时候我们就要借助B了,因为⼩盘⼦必须时刻都在⼤盘
  • 2024-07-12递归【汉塔罗问题】
    汉诺塔(HanoiTower)问题是一个著名的递归问题,最初由法国数学家ÉdouardLucas在1883年发明。这个问题描述如下:有三根柱子A、B、C,以及n个不同大小的圆盘,初始时所有的圆盘都按照从大到小的顺序放在柱子A上。目标是将所有圆盘移到柱子C上,同时遵循以下规则:-每次只能移动一个圆
  • 2023-07-21递归
    递归概念简单的来说,递归就是在函数里面再调用它本身,其目的是把复杂的问题分解成与原问题相似但规模较小的问题来解决,这样大大减少了程序的代码量。递归条件递归是需要一个终止条件的,否则就是一个死循环。比如求\(x^n\),可以转化为\(x^n=x*x^{n-1}\),\(x^{n-1}=x*x^{n-2}\)...而
  • 2023-05-0923-05-09--栈和队列--堆宝塔
     堆宝塔游戏是让小朋友根据抓到的彩虹圈的直径大小,按照从大到小的顺序堆起宝塔。但彩虹圈不一定是按照直径的大小顺序抓到的。聪明宝宝采取的策略如下:首先准备两根柱子,一根A柱串宝塔,一根B柱用于临时叠放。把第1块彩虹圈作为第1座宝塔的基座,在A柱放好。将抓到的下
  • 2023-04-20汉诺塔VII 1997 (技巧+递推)
    汉诺塔VIITimeLimit:2000/1000MS(Java/Others)    MemoryLimit:65536/32768K(Java/Others)TotalSubmission(s):1261    AcceptedSubmission(s):838ProblemDescriptionn个盘子的汉诺塔问题的最少移动次数是2^n-1,即在移动过程中会产生2^n个系列。
  • 2023-01-19如何使用C语言实现汉诺塔
    现有3个柱子A、B、C,有n个圆盘在A柱上,要实现n个圆盘要从A柱从大到小移动到C柱。思路:先将n-1个圆盘移动到B柱上,然后将最后一个圆盘移动到C柱上,最后将B柱上的n-1个圆盘移动到C
  • 2022-09-03C1解决汉诺塔问题
    定义两个函数即可解决一个f(chara,charb)函数,一个g(inti,chara,charb,charc)函数f函数表示把a上一个圆盘移动到b上,g函数表示把a上i个圆盘通过b移动到c上,重复操作