balaaaala 2022-10-24 09:58 采纳率: 100%
浏览 33
已结题

c++汉诺塔函数的盘子数量运行时总是少一个

汉诺塔问题,请问为什么我输入三个盘子但是程序运行出来只显示了盘子一和盘子二呢?


#include <iostream>
using namespace std;
int fun(int n,char A,char B,char C)
{
    if(n==1)
    {
    cout<<"move"<<n<<"from"<<A<<"to"<<C<<endl;//如果只有一个盘子,A到C 
    }
    else
    {
        fun(n-1,A,C,B);//如果有两个盘子,则最上面的先从A到B,再让第二个从A到C,最后让第一个盘子到B到C 
        cout<<"move"<<n-1<<"from"<<A<<"to"<<C<<endl;
        fun(n-1,B,A,C);
    }

}
int main()
{
    int n;
    cout<<"请输入盘子数量:";
    cin>>n; 
    fun(n,'A','B','C');
    return 0;
} 
  • 写回答

1条回答 默认 最新

  • zp_diandiandidi 2022-10-24 10:27
    关注

    你这个是一个递归程序,递归程序要有出口哦,把函数 fun 的返回类型改成 void,然后在 if 语句中 cout 后加 return; 语句。

    望采纳。

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

报告相同问题?

问题事件

  • 系统已结题 11月1日
  • 已采纳回答 10月24日
  • 创建了问题 10月24日

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题