xhily123f1 2014-12-23 09:43 采纳率: 0%
浏览 1739

汉诺塔算法c++出现错误

#include

using namespace std;

//圆盘的个数最多为64
const int MAX = 64;

//用来表示每根柱子的信息
struct st{
int s[MAX]; //柱子上的圆盘存储情况
int top; //栈顶,用来最上面的圆盘
char name; //柱子的名字,可以是A,B,C中的一个

int Top()    //取栈顶元素
{
    return s[top];
}

int Pop()    //出栈
{
 return s[top--];
}

void Push(int x)    //入栈
{
 s[++top] = x;
}

} ;

long Pow(int x, int y); //计算x^y

void Creat(st ta[], int n); //给结构数组设置初值

void Hannuota(st ta[], long max); //移动汉诺塔的主要函数

int main(void)
{
int n;

cin >> n; //输入圆盘的个数
st ta[3]; //三根柱子的信息用结构数组存储
Creat(ta, n); //给结构数组设置初值
long max = Pow(2, n) - 1; //动的次数应等于2^n - 1
Hannuota(ta, max); //移动汉诺塔的主要函数
system("pause");
return 0;
}

void Creat(st ta[], int n)
{
ta[0].name = 'A';
ta[0].top = n-1;

//把所有的圆盘按从大到小的顺序放在柱子A上    
for (int i=0; i<n; i++)
    ta[0].s[i] = n - i;

//柱子B,C上开始没有没有圆盘
ta[1].top = ta[2].top = 0;

for (int i=0; i<n; i++)
    ta[1].s[i] = ta[2].s[i] = 0;

//若n为偶数,按顺时针方向依次摆放 A B C    
if ( n%2 == 0)
{    
    ta[1].name = 'B';
 ta[2].name = 'C';
}
else //若n为奇数,按顺时针方向依次摆放 A C B
{
    ta[1].name = 'C';
 ta[2].name = 'B';
}

}

long Pow(int x, int y)
{
long sum = 1;

for (int i = 0; i < y; i++)
    sum *= x; 

return sum;

}

void Hannuota(st ta[], long max)
{
int k = 0; //累计移动的次数
int i = 0;
int ch;

  while (k < max)
  {
    //按顺时针方向把圆盘1从现在的柱子移动到下一根柱子
    ch = ta[i%3].Pop();

     ta[(i+1)%3].Push(ch);

       cout << ++k << ": " << "Move disk " << ch << " from " 
       << ta[i%3].name <<" to " << ta[(i+1)%3].name << endl;

       i++;

       //把另外两根柱子上可以移动的圆盘移动到新的柱子上
       if (k < max)
       {
        //把非空柱子上的圆盘移动到空柱子上,当两根柱子都为空时,移动较小的圆盘
        if (ta[(i+1)%3].Top() == 0 || ta[(i-1)%3].Top() > 0 
            && ta[(i+1)%3].Top() > ta[(i-1)%3].Top())
        {
            ch = ta[(i-1)%3].Pop();
            ta[(i+1)%3].Push(ch);
            cout << ++k << ": " << "Move disk " << ch << " from " 
            << ta[(i-1)%3].name << " to " << ta[(i+1)%3].name << endl;
        }
        else
     {
               ch = ta[(i+1)%3].Pop();
               ta[(i-1)%3].Push(ch);
               cout << ++k << ": " << "Move disk " << ch << " from " 
               << ta[(i+1)%3].name << " to " << ta[(i-1)%3].name << endl;
        }
     }
}

}

vc6.0运行有错误啊

  • 写回答

3条回答 默认 最新

报告相同问题?

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决