汉诺塔问题的非递归非堆栈算法(一)

#include <iostream.h>
#include <math.h>
#define maxno 10000
int step_d,step_s,no;//定义将要行进的步数
void main()
{
 cout<<"请输入数字(1-64):";
 cin>>no;//获取实际的塔片数
 //初始化

 int **p=new int*[3];

 p[0]=new int[no+1];

 p[1]=new int[no+1];

 p[2]=new int[no+1]; 
  p[0][0]=maxno;p[1][0]=maxno;p[2][0]=maxno;
 for(int count=1;count<=no;count++)
 {
 p[0][count]=no-count+1;
 p[1][count]=0;
 p[2][count]=0;
 }
 //初始化完毕
 if(fmod(no,2)){step_s=2;step_d=1;}else {step_s=1;step_d=2;}//判断奇数盘的步数和偶数盘的步数
 int from,to;
 from=0;
 to=step_s+from;
 p[0]=&p[0][no];
 while(*(p[0]) !=  *(p[1]))
 { 
  cout<<"从柱:"<<from+1<<" 到柱: "<<to+1<<endl;
        *(++p[to])=*(p[from]);
        *(p[from]--)=0;
  //以下求得下一步将要From移动的柱子
  switch(to)
  {
   case 2:
                if(*(p[0]) < *(p[1]))from=0;else from=1;
    break;
   case 1:
                if(*(p[0]) < *(p[2]))from=0;else from=2;
    break;
   case 0:
                if(*(p[2]) < *(p[1]))from=2;else from=1;
    break;
  }  
  //以下一行求得下一步将要移动到的柱子
  if(fmod(*(p[from]),2))to=fmod(from+step_s,3);else to=fmod(from+step_d,3);
 } 
 char c;
 cin>>c;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值