X星球居民小区的楼房全是一样的,并且按矩阵样式排列。其楼房的编号为1,2,3... 当排满一行时,从下一行相邻的楼往反方向排号。 比如:当小区排号宽度为6时,开始情形如下:

1 2 3 4 5 6

12 11 10 9 8 7

13 14 15 .....

我们的问题是:已知了两个楼号m和n,需要求出它们之间的最短移动距离(不能斜线方向移动)

要求输出一个整数,表示m n 两楼间最短移动距离。

输入格式:

在一行中输入为3个整数w m n,空格分开,都在1到10000范围内 w为排号宽度,m,n为待计算的楼号。

输出格式:

要求输出一个整数,表示m n 两楼间最短移动距离。

输入样例1:

6 8 2

输出样例1:

4

输入样例2:

4 7 20

输出样例2:

5


先算垂直距离,再算水平距离。
代码:
#include <iostream>
#include <algorithm>
#include <map>
#include <cstring>
#include <cstdio>
using namespace std;

int main()
{
    int w,m,n;
    scanf("%d%d%d",&w,&m,&n);
    m --,n --;
    int mm = m / w,nn = n / w;
    int d = abs(nn - mm);
    m %= w;
    n %= w;
    if(mm % 2)m = w - 1 - m;
    if(nn % 2)n = w - 1 - n;
//    cout<<m<<' '<<n<<' ';
    d += abs(n - m);
    cout<<d;
}

 2019重做:

#include <iostream>
#include <cstdlib>
using namespace std;
int w,m,n;
int main() {
    cin>>w>>m>>n;
    m --,n --;
    if(m / w % 2) {
        m = m / w * w + w - 1 - m % w;
    }
    if(n / w % 2) {
        n = n / w * w + w - 1 - n % w;
    }
    cout<<abs(m / w - n / w) + abs(m % w - n % w);
}

把每个数对应到正常的位置上,比如宽度是6,题目中的7的位置实际上应该是12,变换之后求距离就好求了