首页 > 编程语言 > 详细

北京大学 程序设计与算法(二)递归 汉诺塔

时间:2020-02-16 18:35:52      阅读:84      评论:0      收藏:0      [点我收藏+]

古代有一个梵塔,塔内有三个座A,B,C。A座上有64个盘子,盘子大小不等,大的在下,小的在上(如图)。有一个和尚想把这64个盘子从A座移到C座,但每次只能允许移动一个盘子,并且在移动过程中,3个座上的盘子始终保持大盘在下,小盘在上。在移动过程中可以利用B座,要求输出移动的步骤。

 

 

基本思路:把问题分解位先把A座n-1个盘子移动到B座,1个移上C座并且保持不动,

#include<bits/stdc++.h>

using namespace std;

void Hanoi(int n,char src,char mid,char dest)

{if(n==1){//只需移动一个盘子

       cout<<src<<"->"<<dest<<endl; //直接将盘子从src移动到dest

return;}

Hanoi(n-1,src,dest,mid);//先将n-1个盘子从src移动到mid

cout<<src<<"->"<<dest<<endl;

Hanoi(n-1,mid,src,dest);//最后将n-1个盘子从min移动到desr

return;

}

 

int main(){

       int n;

       cin>>n;

       Hanoi(n,‘A‘,‘B‘,‘C‘);

       return 0;

      

}

北京大学 程序设计与算法(二)递归 汉诺塔

原文:https://www.cnblogs.com/Invictus-Gaming/p/12317462.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!