标题:请问关于汉诺塔,如何显示最终的结果,而不是步骤
只看楼主
yxq211046
Rank: 2
等 级:论坛游民
帖 子:22
专家分:36
注 册:2014-4-17
结帖率:100%
已结贴  问题点数:20 回复次数:4 
请问关于汉诺塔,如何显示最终的结果,而不是步骤
网上找到的都是移动步骤,如果想看运行后的结果,比如在数组C中的排列顺序,而不是具体的移动过程,请问该如何编写。谢谢!
搜索更多相关主题的帖子: 如何 网上 
2014-05-08 11:03
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
得分:7 
把輸出語句移到最後

授人以渔,不授人以鱼。
2014-05-08 12:11
yxq211046
Rank: 2
等 级:论坛游民
帖 子:22
专家分:36
注 册:2014-4-17
得分:0 
额,能详细点吗,如果能给出代码更好
 网上找到的代码没有输出语句啊
2014-05-08 14:22
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
得分:7 

总有那身价贱的人给作业贴回复完整的代码
2014-05-08 15:05
yxq211046
Rank: 2
等 级:论坛游民
帖 子:22
专家分:36
注 册:2014-4-17
得分:0 
程序代码:
#include<iostream>
#define PAN 3;
using namespace std;
void move(int a[], int b[])
{
    int i, j;
    i = 3-1;
    j = 3-1;
    if (a[i]!=0)
        i--;
    if (b[j]!=0)
        j--;
    b[j] = a[i+1];
    a[i+1] = 0;
}
void hanoi(int n, int A[], int B[], int C[])
{
    if (n == 1)
        move(A, C);
    else
    {
        hanoi(n - 1, A, B, C);
        move(A, C);
        hanoi(n - 1, B, A, C);
    }
}
int main()
{
    int aa[3];
    int bb[3] = {0};
    int cc[3] = {0};
    int i, j;
    for (i = 0; i < 3; i++)
        aa[i] = i + 1;
    hanoi(3, aa, bb, cc);
    for (j = 0; j < 3; j++)
        cout <<cc[j] << "  ";
    cout << endl;
    return 0;
}

我自己想的,运行出错,显示为 0 0 3
还有把3换成PAN则很多地方出错
2014-05-10 16:57



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-431192-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.342881 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved