最少步数

最少步数(step)

【问题描述】

 在各种棋中,棋子的走法总是一定的,如中国象棋中马走“日”。有一位小学生就想如果马能有两种走法将增加其趣味性,因此,他规定马既能按“日”走,也能如象一样走“田”字。他的同桌平时喜欢下围棋,知道这件事后觉得很有趣,就想试一试,在一个(100*100)的围棋盘上任选两点A、B,A点放上黑子,B点放上白子,代表两匹马。棋子可以按“日”字走,也可以按“田”字走,俩人一个走黑马,一个走白马。谁用最少的步数走到左上角坐标为(1,1)的点时,谁获胜。现在他请你帮忙,给你A、B两点的坐标,想知道两个位置到(1,1)点可能的最少步数。

【输入样例】

 12 16      

 18 10

【输出样例】

 8  9

 

#include

#include

using namespace std;

inta[120][120]={0},b[120][120]={0},x[12]={-2,-2,-1,1,2,2,1,-1,-2,-2,2,2},y[12]={-1,1,2,2,1,-1,-2,-2,-2,2,2,-2};

int main()

{

       freopen("step.in","r",stdin);

       freopen("step.out","w",stdout);

       intx1,y1,x2,y2,i,j,head=0,tail=0,l,q1[10010]={0},q2[10010]={0};

       cin>>x1>>y1;

       cin>>x2>>y2;

       a[1][1]=1;

       b[1][1]=0;

       tail++;

       q1[tail]=1;

       q2[tail]=1;

       while(head

              {

                 i=q1[head+1];

                 j=q2[head+1];

                for (l=1;l<=12;l++)

                         if(i+x[l]<=100&&i+x[l]>0&&j+y[l]<=100&&j+y[l]>0&&a[i+x[l]][j+y[l]]==0)

                           {

                             tail++;

                             q1[tail]=i+x[l];

                             q2[tail]=j+y[l];

                             a[i+x[l]][j+y[l]]=1;

                                     b[i+x[l]][j+y[l]]=b[i][j]+1;//最先扩展到该点的一定是最小步数

                                     cout<<i+x[l]<<""<<j+y[l]<<" "<<i<<""<<j<<endl; 

                          if(a[x1][y1]==1&&a[x2][y2]==1)

                               {

                                   cout<<b[x1][y1]<<endl;

                                   cout<<b[x2][y2]<<endl;

                                   return 0;

                               }

                           }

                head++;

            }

}

此题可以看做从(1,1)走至少多少步可到达目标节点


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华容道是一种经典的益智游戏,玩家需要通过移动方块的位置来完成拼图。要计算华容道移动的最少步数,需要使用C语言编写程序来实现。 首先,我们可以使用二维数组来表示华容道的棋盘,其中每个位置可用数字表示方块的类型。例如,数字0表示空白位置,其他数字表示方块。 接下来,我们需要编写一个函数来计算华容道的最少步数。该函数需要使用搜索算法来遍历所有可能的移动步骤,并记录移动的步数。在搜索过程中,我们需要判断每一步是否有效,并且需要记录已经访问过的状态,避免重复搜索。 可以使用递归来实现搜索算法。函数的输入参数包括当前的棋盘状态、已经移动的步数、块的位置和目标位置。在函数的内部,我们可以逐个判断每个方向的移动是否有效,并计算移动后的新状态。如果移动后的状态已经达到终止条件,我们可以返回移动的步数。如果移动后的状态无效或者已经访问过,我们需要继续搜索其他可能的移动方式。 最后,我们需要定义一个主函数来调用计算最少步数的函数。主函数需要读取输入的棋盘状态,并将结果输出到控制台。 通过以上步骤,我们就可以使用C语言编写一个计算华容道移动最少步数的程序了。这个程序将会遍历所有可能的移动步骤,并使用搜索算法来计算最少步数

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值