小编给大家分享一下C++如何实现汉诺塔,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
网站建设哪家好,找成都创新互联公司!专注于网页设计、网站建设、微信开发、小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了平度免费建站欢迎大家使用!
C++ 实现汉诺塔的实例详解
前言:
有A,B,C三塔,N个盘(从小到大编号为1-N)起初都在A塔,现要将N个盘全部移动到C塔(按照河内塔规则),求最少移动次数以及每次的移动详细情况。
要求:
需要采用递归方法和消除尾递归两种方法编写。
盘数N由用户从标准输入读入,以一个整数表示,然后请调用两个方法按照下面例子所述分别在屏幕中输出结果(正常情况下一个输入数据会显示同样的输出结果2次)。
实现代码:
#include<iostream> using 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 "<<count<<" from "<<start<<" to "<<finish<<endl; move(count-1,temp,finish,start); } } void move_without_recursion(int count,char start='a',char finish='b',char temp='c') { char swap; while(count>0) { move_without_recursion(count-1,start,temp,finish); cout<<"Move "<<count<<" from "<<start<<" to "<<finish<<endl; count--; swap=start; start=temp; temp=swap; } } int main() { int count; cout<<"please enter the number:"; cin>>count; cout<<"递归方法运行过程:"<<endl; move(count); cout<<"消除尾递归方法运行过程:"<<endl; move_without_recursion(count); return 0; }
以上是“C++如何实现汉诺塔”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
当前名称:C++如何实现汉诺塔
转载注明:https://www.cdcxhl.com/article12/gdjogc.html
成都网站建设公司_创新互联,为您提供做网站、自适应网站、定制开发、面包屑导航、网站收录、商城网站
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联