校园三键客 2022-05-09 16:12 采纳率: 60%
浏览 73
已结题

汉诺塔c++解答123

题目描述

汉诺塔的问题大家都已经很熟悉了,有三个柱子,第1个A柱子上有一些大小不一的n个金片,初始状态下保证金片从上到下按照从小到大的顺序叠放,并按照1~n的顺序编号。

要把金片从A柱移动到C柱,可以借助B柱,移动过程中不能出现大金片在小金片上面的情况。

现增加一条规则:移动过程中,只允许将金片移到相邻的柱子,也就是可以从A柱移动金片到B柱,但不能从A直接移动金片到C柱;也就是说,每次移动一定会移动到B柱,或者从B柱移出。

请问:如果有n个金片需要从A柱移动到C柱,应该怎样移动。
输入

一个整数n,代表A柱上金片的数量。(n≤5)
输出

输出若干行,第i行输出第i步需要将哪个立柱上的金片移动到哪个立柱。
样例
输入

2

输出

A To B
B To C
A To B
C To B
B To A
B To C
A To B
B To C

#include<bits/stdc++.h>
using namespace std;
void fun(int n,char p1,char p2,char p3){
    if(n>0){
        fun(n-1,p1,p3,p2);
        cout<<p1<<" To "<<p3<<endl;
        fun(n-1,p2,p1,p3);
    }
}
int main(){
    int n;
    cin>>n;
    fun(n,'A','B','C');
    return 0;
}

改一下

  • 写回答

1条回答 默认 最新

  • 校园三键客 2022-05-10 11:15
    关注

    #include <bits/stdc++.h>
    using namespace std;
    void move(int n,char p1,char p2,char p3){
    if(n > 0){
    move(n-1,p1,p2,p3);
    cout<<p1<<" To "<<p3<<endl;
    move(n-1,p2,p1,p3);
    cout<<p3<<" To "<<p2<<endl;
    move(n-1,p1,p2,p3);
    }
    }
    int main(){
    int n;
    cin>>n;
    move(n,'A','C','B');
    return 0;
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 5月18日
  • 已采纳回答 5月10日
  • 创建了问题 5月9日

悬赏问题

  • ¥15 有偿求苍穹外卖环境配置
  • ¥15 代码在keil5里变成了这样怎么办啊,文件图像也变了,
  • ¥20 Ue4.26打包win64bit报错,如何解决?(语言-c++)
  • ¥15 clousx6整点报时指令怎么写
  • ¥30 远程帮我安装软件及库文件
  • ¥15 关于#自动化#的问题:如何通过电脑控制多相机同步拍照或摄影(相机或者摄影模组数量大于60),并将所有采集的照片或视频以一定编码规则存放至规定电脑文件夹内
  • ¥20 深信服vpn-2050这台设备如何配置才能成功联网?
  • ¥15 Arduino的wifi连接,如何关闭低功耗模式?
  • ¥15 Android studio 无法定位adb是什么问题?
  • ¥15 C#连接不上服务器,