C 语言搞定汉诺塔问题:算法、程序及时空复杂度揭秘
以下是用 C 语言解决汉诺塔问题的程序: ```c #include <stdio.h> // 移动盘子的函数 void hanoi(int n, char from_rod, char to_rod, char aux_rod) { if (n == 1) { printf("Move disk 1 from rod %c to rod %c\n", from_rod, to_rod); return; } hanoi(n - 1, from_rod, aux_rod, to_rod); printf("Move disk %d from rod %c to rod %c\n", n, from_rod, to_rod); hanoi(n - 1, aux_rod, to_rod, from_rod); } int main() { int n = 3; // 要移动的盘子数量,可修改 hanoi(n, 'A', 'C', 'B'); return 0; } ``` 汉诺塔问题的时间复杂度为 $O(2^n)$ ,空间复杂度为 $O(n)$ 。这是因为汉诺塔问题的递归调用次数呈现指数增长,而递归调用栈的深度最大为盘子的数量 $n$ 。 ######[AI写代码神器 | 275点数解答 | 2024-11-08 12:44:23]
相关提问
- C++求解序列或与运算和差值:避O(nq)复杂度及数据处理要点(字节豆包 | 534点数解答 | 2025-10-17 20:05:07)75
- C++ 破解“没有 3 的世界”:找出第 n 个特殊正整数!(字节豆包 | 333点数解答 | 2025-03-17 22:48:43)166
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)352
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)304
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)381
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)381
- 超范围数字乘法:字符串转数组+模拟竖式运算的实现攻略( | 377点数解答 | 2024-03-17 10:58:21)380
- Java 实现:突破 long 范围限制,模拟竖式运算处理大数字乘法( | 14点数解答 | 2024-03-17 10:58:39)357
- Java实现:突破long范围限制,模拟人工竖式运算大数字乘法( | 1022点数解答 | 2024-03-17 10:59:43)364
- C语言实现:从键盘输入正整数,轻松判断是否为素数(百度文心 | 576点数解答 | 2024-11-10 19:38:17)355
- C 语言:用欧几里得算法从键盘输入两数求最大公约数(附代码及注意点)(字节豆包 | 277点数解答 | 2024-12-31 10:47:11)307
- Python 在 Windows 系统下编程实现 RSA 算法对照片加密与解密(字节豆包 | 373点数解答 | 2025-01-05 18:35:28)376