题目链接:传送门 题目大意: 汉诺塔,给定n个盘子(n <= 45),起始状态和结束状态,求最小的步数以及路径. 思路: 考虑用dfs贪心地将剩余最大盘归位. #include<bits/stdc++.h> using namespace std; ; ; int N, ans; int f1[MAX_N], f2[MAX_N]; void dfs(int cur, int st, int ed, bool now) { int mid = SUM - st - ed; if (st =
借助堆栈以非递归(循环)方式求解汉诺塔的问题(n, a, b, c), 即将N个盘子从起始柱(标记为“a”)通过借助柱(标记为“b”)移动到目标柱(标记为“c”), 并保证每个移动符合汉诺塔问题的要求. 输入格式: 输入为一个正整数N,即起始柱上的盘数. 输出格式: 每个操作(移动)占一行,按柱1 -> 柱2的格式输出. 输入样例: 输出样例: a -> c a -> b c -> b a -> c b -> a b -> c a -> c 递归思路: (1