小编给大家分享一下C++如何实现汉诺塔,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
成都创新互联公司是一家专注于成都网站建设、成都网站制作与策划设计,玉环网站建设哪家好?成都创新互联公司做网站,专注于网站建设十余年,网设计领域的专业建站公司;建站业务涵盖:玉环等地区。玉环做网站价格咨询:18982081108C++ 实现汉诺塔的实例详解
前言:
有A,B,C三塔,N个盘(从小到大编号为1-N)起初都在A塔,现要将N个盘全部移动到C塔(按照河内塔规则),求最少移动次数以及每次的移动详细情况。
要求:
需要采用递归方法和消除尾递归两种方法编写。
盘数N由用户从标准输入读入,以一个整数表示,然后请调用两个方法按照下面例子所述分别在屏幕中输出结果(正常情况下一个输入数据会显示同样的输出结果2次)。
实现代码:
#includeusing namespace std; void move(int count,char start='a',char finish='b',char temp='c') { if(count>0) { move(count-1,start,temp,finish); cout<<"Move "< 0) { move_without_recursion(count-1,start,temp,finish); cout<<"Move "< >count; cout<<"递归方法运行过程:"< 以上是“C++如何实现汉诺塔”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章标题:C++如何实现汉诺塔-创新互联
文章转载:http://cxhlcq.com/article/jjgdp.html