博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
汉诺塔问题
阅读量:6638 次
发布时间:2019-06-25

本文共 711 字,大约阅读时间需要 2 分钟。

  hot3.png

一,移动次数的计算

  现在有三根相邻的柱子,标号为A,B,C,A柱子上从下到上按金字塔状叠放着n个不同大小的圆盘,现在把所有盘子一个一个移动到柱子B上,并且每次移动同一根柱子上都不能出现大盘子在小盘子上方,请问至少需要多少次移动,设移动次数为H(n)。   首先我们肯定是把上面n-1个盘子移动到柱子C上,然后把最大的一块放在B上,最后把C上的所有盘子移动到B上,由此我们得出表达式:   H⑴ = 1   H(n) = 2*H(n-1)+1 (n>1)   那么我们很快就能得到H(n)的一般式:   H(n) = 2^n - 1 (n>0)

二,输出移动路径

思路: 把n-1个饼移到B,再把第n个饼移到C,最后把n-1个饼移到C。

#include 
int count;void hanoi(int n,char a,char b,char c){ if(n==1) { printf("第%d次,%c柱-->%c柱\n",++count,a,c); } else { hanoi(n-1,a,c,b); printf("第%d次,%c柱-->%c柱\n",++count,a,c); hanoi(n-1,b,a,c); }} int main(){ int num; printf("请输入A柱汉诺塔盘子的数量:"); scanf("%d",&num); count=0; hanoi(num,'A','B','C'); return 0;}

转载于:https://my.oschina.net/lin546/blog/1541602

你可能感兴趣的文章
C++基础入门
查看>>
Android移动view动画问题
查看>>
Jpeg图片显示过程
查看>>
1.java.io包中定义了多个流类型来实现输入和输出功能,
查看>>
Bootstrap下拉菜单
查看>>
NSUserDefaults 保存自己定义对象
查看>>
ubuntu11.04 flash插件安装
查看>>
基础数据结构-串-KMP算法
查看>>
flask总结01
查看>>
Raspberry Pi开发之旅-实现云平台监控
查看>>
QT开发之旅-Udp聊天室编程
查看>>
c++类型转换
查看>>
Java IO编程全解(六)——4种I/O的对比与选型
查看>>
(iOS)确保设置话筒模式成功 AudioSessionSetProperty
查看>>
复习笔记:一个简单的反射工厂Demo
查看>>
Google Drive 云端硬盘 可以选择多个文件上传的前端实现
查看>>
or ||
查看>>
编辑一次性计划任务
查看>>
MAC下的mysql忘记密码该怎么办??
查看>>
matlab练习程序(立体相关块匹配)
查看>>