- 作 者:刘泽齐
- 完成日期:2017年9月22日
- 问题描述:汉诺塔
- 问题及代码
运行结果:#include <stdio.h> #define discCount 4 long move(int, char, char,char); int main() { long count; count=move(discCount,'A','B','C'); printf("%d个盘子需要移动%ld次\n", discCount, count); return 0; } long move(int n, char A, char B,char C) { long c1,c2; if(n==1) return 1; else { c1=move(n-1,A,C,B); c2=move(n-1,B,A,C); return c1+c2+1; } }
知识点总结:随着盘子数的增加,需要移动的次数也随之增加
学习心得:用递归算法求解汉诺塔问题,其复杂度可以求得为
O(2n)
,是指数级的算法。盘子数discCount为4、8时在时间耗费上的差异越来越大