最少步数

最少步数 

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

输入

A、B两点的坐标。

输出

最少步数。

样例输入

12 16
18 10

样例输出

8
9

#include<bits/stdc++.h>
using namespace std;
int dir[][2]={{1,2},{2,1},{-1,2},{2,-1},{-2,1},{1,-2},{-1,-2},{-2,-1},
				{-2,-2},{-2,2},{2,-2},{2,2}};//走田和日共12个方向 
int map1[105][105];
int list1[105*105][2];
int main()
{
	int ax,ay,bx,by;
	for(int j=1;j<=2;j++)
	{
		scanf("%d%d",&ax,&ay);
	memset(map1,0,sizeof(map1));
	
	int t,w,flag;
	flag=0;
	t=1,w=1;
	list1[t][0]=ax;
	list1[t][1]=ay;
	map1[ax][ay]=0;
	t++;
	while(t>w)
	{
		if(flag==1)
			break;
		for(int i=0;i<12;i++)
		{
			int dx=list1[w][0]+dir[i][0];
			int dy=list1[w][1]+dir[i][1];
				if(dx<1 || dx>100 || dy<1 || dy>100 || map1[dx][dy]!=0) 
					continue; //除了边界或已经走过了 
					
				map1[dx][dy]=map1[list1[w][0]][list1[w][1]]+1;
				
				if(dx==1 && dy==1)
				{
					flag==1;
					break;
				}
				list1[t][0]=dx;
				list1[t][1]=dy;
				t++;
		} 
		w++;
	}
	printf("%d\n",map1[1][1]);
	}
	
	
	return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值