Chinaunix首页 | 论坛 | 博客
  • 博客访问: 129545
  • 博文数量: 44
  • 博客积分: 956
  • 博客等级: 准尉
  • 技术积分: 521
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-18 12:45
文章分类
文章存档

2012年(11)

2011年(33)

分类: C/C++

2011-12-13 18:39:55

汉诺塔是递归思想的典型应用~
  1. #include <stdio.h>

  2. void hanoi(int n, char x, char y, char z);

  3. int main(void)
  4. {
  5.     hanoi(3, 'A', 'B', 'C');
  6.     return 0;
  7. }

  8. void hanoi(int n, char x, char y, char z)
  9. {
  10.     if (n > 0){
  11.         hanoi(n-1, x, z, y);
  12.         printf("%c ----> %c\n", x, z);
  13.         hanoi(n-1, y, x, z);
  14.     }
  15. /*
  16.     伪算法:
  17.     
  18.     如果(x上还有盘子){
  19.         将 x 上面n-1个盘子借助 z 移动到 y上;
  20.         将 x 最下面的盘子移动到 z 上
  21.         将 y 上面的盘子借助 x 移动到 z上
  22.     }
  23. */
  24. }
阅读(1174) | 评论(0) | 转发(0) |
0

上一篇:C语言基础(5)

下一篇:C语言高级(6)

给主人留下些什么吧!~~