| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 486 人关注过本帖
标题:请问关于汉诺塔,如何显示最终的结果,而不是步骤
取消只看楼主 加入收藏
yxq211046
Rank: 2
等 级:论坛游民
帖 子:22
专家分:36
注 册:2014-4-17
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
请问关于汉诺塔,如何显示最终的结果,而不是步骤
网上找到的都是移动步骤,如果想看运行后的结果,比如在数组C中的排列顺序,而不是具体的移动过程,请问该如何编写。谢谢!
搜索更多相关主题的帖子: 如何 网上 
2014-05-08 11:03
yxq211046
Rank: 2
等 级:论坛游民
帖 子:22
专家分:36
注 册:2014-4-17
收藏
得分:0 
额,能详细点吗,如果能给出代码更好
 网上找到的代码没有输出语句啊
2014-05-08 14:22
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
快速回复:请问关于汉诺塔,如何显示最终的结果,而不是步骤
数据加载中...
 
   



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

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