汉诺塔:
相传在古印度圣庙中,有一种被称为汉诺塔(Hanoi)的游戏。该游戏是在一块铜板装置上,有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺序放置64个金盘(如图1)。游戏的目标:把A杆上的金盘全部移到C杆上,并仍保持原有顺序叠好。操作规则:每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下,小盘在上,操作过程中盘子可以置于A、B、C任一杆上
对于这样一个问题,任何人都不可能直接写出移动盘子的每一步,但我们可以利用下面的方法来解决。设移动盘子数为n,为了将这n个盘子从A杆移动到C杆,可以做以下三步:
(1)以C盘为中介,从A杆将1至n-1号盘移至B杆;
(2)将A杆中剩下的第n号盘移至C杆;
(3)以A杆为中介;从B杆将1至n-1号盘移至C杆。
老师的代码:
#include <stdio.h>
/**
* Hanoi.
*/
void hanoi(int paraN, char paraSource, char paraDestination, char paraTransit) {
if (paraN <= 0) {
return;
} else {
hanoi(paraN - 1, paraSource, paraTransit, paraDestination);
printf("%c -> %c \r\n", paraSource, paraDestination);
hanoi(paraN - 1, paraTransit, paraDestination, paraSource);
}// Of if
}// Of hanoi
/**
* Test the hanoi function.
*/
void hanoiTest() {
printf("---- addToTest begins. ----\r\n");
printf("2 plates\r\n");
hanoi(2, 'A', 'B', 'C');
printf("3 plates\r\n");
hanoi(3, 'A', 'B', 'C');
printf("---- addToTest ends. ----\r\n");
}// Of addToTest
/**
The entrance.
*/
void main() {
hanoiTest();
}// Of main
老师的运行结果:
---- addToTest begins. ----
2 plates
A -> C
A -> B
C -> B
3 plates
A -> B
A -> C
B -> C
A -> B
C -> A
C -> B
A -> B
---- addToTest ends. ----
Press any key to continue
代码实现:
#include <stdio.h>
/**
* @brief 汉诺塔移动递归函数
*
* @param paraDestination
* @param paraN
* @param paraSource
* @param paraTransit
*/
int cnt=0;
void hanoi(int paraN, char paraSource, char paraDestination, char paraTransit) {
if (paraN <= 0) {
return;
} else {
cnt++;
hanoi(paraN - 1, paraSource, paraTransit, paraDestination);
printf(" %c -> %c \n", paraSource, paraDestination);
hanoi(paraN - 1, paraTransit, paraDestination, paraSource);
}
}
/**
* @brief 测试类
*/
void hanoiTest() {
printf("---- addToTest 开始 ----\n");
int N;
printf("请输入加入的盘子数:");
scanf("%d",&N);
printf("%d个盘子的移动过程:\n",N);
hanoi(N, 'A', 'B', 'C');
printf("共移动%d次\n\n",cnt);
printf("---- addToTest 结束 ----");
}
int main(){
hanoiTest();
return 0;
}
n=3时
---- addToTest 开始 ----
请输入加入的盘子数:3
3个盘子的移动过程:
A -> B
A -> C
B -> C
A -> B
C -> A
C -> B
A -> B
共移动7次
---- addToTest 结束 ----
时间复杂度是 O (2^n), 空间复杂度是 O(n).