快乐打码 2023-02-15 20:41 采纳率: 71.4%
浏览 25
已结题

j汉诺塔不是这样写的吗,为什么会是错的,要怎么改才对

请编写函数,完成移动汉诺塔的任务。

函数原型
void MoveTower(int num, char src, char dst, char trs);
说明:参数 num 为金片数,src、dst 和 trs 分别为起始柱、目的柱和过渡柱。若金片数大于 0,则函数将金片组成的汉诺塔由起始柱利用过渡柱最终搬到目的柱,否则什么也不做。

下面的程序,输入汉诺塔圆片的数量,输出移动汉诺塔的步骤。

裁判程序

#include <stdio.h>

void MoveTower(int num, char src, char dst, char trs);

int main()
{
    int n;
    char s, d, t;
    scanf("%d %c %c %c", &n, &s, &d, &t);
    MoveTower(n, s, d, t);
    return 0;
}

/* 你提交的代码将被嵌在这里 */

输入格式
圆盘数
起始柱 目的柱 过渡柱

输出格式
移动汉诺塔的步骤
每行显示一步操作,具体格式为:
盘片号: 起始柱 -> 目的柱
其中盘片号从 1 开始由小到大顺序编号。

输入样例
3
a c b
输出样例
1: a -> c
2: a -> b
1: c -> b
3: a -> c
1: b -> a
2: b -> c
1: a -> c

void MoveTower(int num,char src,char dst,char trs)
{
    if(num==1)
        printf("%d: %c -> %c\n",num,src,trs);
    else
    {
         MoveTower(num-1,src,trs,dst);
        printf("%d: %c -> %c\n",num,src,trs);
        MoveTower(num-1,dst,src,trs);
    }    
}


  • 写回答

1条回答 默认 最新

  • 社区专家-Monster-XH 2023-02-15 21:04
    关注

    你提供的程序中,第二个 MoveTower 函数调用有问题。原来的调用是 MoveTower(num-1, dst, src, trs);,应该改为 MoveTower(num-1, trs, dst, src);。

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

报告相同问题?

问题事件

  • 系统已结题 2月23日
  • 已采纳回答 2月15日
  • 创建了问题 2月15日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效