首页 > 移动平台 > 详细

移动距离(15 分)

时间:2018-02-12 14:27:45      阅读:249      评论:0      收藏:0      [点我收藏+]

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;
}

 

移动距离(15 分)

原文:https://www.cnblogs.com/8023spz/p/8444420.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!