Bee Breeding UVA - 808

题意:输入两个格子的编号a和b(a,b<=10000),求最短距离

思路:建坐标系找规律,参考他人思路思路链接

#include <bits/stdc++.h>
#define ll long long
#define ull unsigned long long
#define INF 0x3f3f3f3f
#define mod 1000000007;
using namespace std;
//    freopen("in.txt","r",stdin);
//    freopen("out.txt","w",stdout);
const int maxn = 20000 + 2;
struct node
{
    int x,y;
    node(){}
    node(int a,int b)
    {
        x = a;
        y = b;
    }
}p[maxn];
int dx[] = {-1,0,1,1,0};
int dy[] = {1,2,1,-1,-2};
void init()
{
    int x = 0,y = 0,num = 1;
    p[num++] = node(x,y);
    y -= 2;
    p[num++] = node(x,y);
    for(int i = 1;i <= 60;i++)
    {
        for(int j = 0;j < 5;j++)
        {
            for(int k = 0;k < i;k++)
            {
                x += dx[j],y += dy[j];
                p[num++] = node(x,y);
            }
        }
        y -= 2;
        p[num++] = node(x,y);
        for(int j = 0;j < i;j++)
        {
            x--,y--;
            p[num++] = node(x,y);
        }
    }
}
int main()
{
    int a,b;
    init();
    while(scanf("%d%d",&a,&b) && a + b)
    {
        int x = abs(p[a].x - p[b].x);
        int y = abs(p[a].y - p[b].y);
        printf("The distance between cells %d and %d is ",a,b);
        if(x >= y) printf("%d.\n",x);
        else printf("%d.\n",x + (y - x) / 2);
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值