Description:
如图为一个三角迷宫,迷宫中的数字从1开始标号。现给出两个数字m、n,请求出从m到n的最短路径,输出路径长度。
注:如图所示,迷宫中的数字被网格线所分隔,我们规定,穿过一次网格线,路径长度加一,初始路径长度为0。
Input:
第一行,一个整数T(0≤T≤106)。
接下来T行,每行两个整数,m、n(1≤m,n≤1e9)。
Output:
输出T行,每行一个整数,表示结果。
Sample Input:
1
6 12
Sample Output:
3
从三个角度看这个图,level,left,right,如下图,题目的答案就是3个图上2个点之间的层数的高度差之和。
#include<stdio.h>
#include<math.h>
using namespace std;
int main()
{
int m,n,cm,cn,rm,rn,lm,ln; //c表示level图 ,r表示right图,l表示left图
while(scanf("%d%d",&m,&n)!=EOF)//
{
cm=(int)ceil(sqrt(m));//ceil为向上取整函数“math.h”
cn=(int)ceil(sqrt(n));
rm=(m-(cm-1)*(cm-1)-1)/2+1; //确定m在right图中的哪一层
rn=(n-(cn-1)*(cn-1)-1)/2+1; //确定n在right图中的哪一层
lm=(cm*cm-m)/2+1; //确定m在left图中的哪一层
ln=(cn*cn-n)/2+1; //确定n在left图中的哪一层
int cnt=(int)(fabs(cm-cn)+fabs(lm-ln)+fabs(rm-rn));
printf("%d\n",cnt);
}
return 0;
}