题意

B 君的第三题(zhengzhou)

题目描述

让你在战争和耻辱中做一块选择,你选择耻辱,可你将来还得进行战争。

在平面上有n 个整点(横纵坐标都是整数)

B 君想找到一个整点,使得这个点,到所有点的距离之和最小。

两个点的距离定义为从一个点到到另一个点的最小步数。

其中每步可以走向相邻8 个点(上,下,左,右,左上,左下,右上,右下,类似国际象棋中的王)走一步。

输出这个最小的距离之和。

和这个点选择的方案数。(即有多少个点,可以达到这个最小的距离)

输入格式

第一行一个整数n 表示点数。

接下来n 行,每行两个整数x, y。描述一个点。

输出格式

第一行输出最小的距离之和。

第二行输出有多少个点,可以达到这个最小距离。

样例输入一

4

0 0

0 2

2 0

2 2

样例输出一

4

1

样例解释一

选择(1, 1)。

样例输入二

4

2 1

1 2

0 1

1 0

样例输出二

4

5

样例解释二

可以选择输入的4 个点之一,或者(1, 1)。

样例输入三

3

0 1

1 0

0 0

样例输出三

2

3

样例解释三

可以选择输入的3 个点之一。

数据规模与约定

对于100% 的数据,满足\(1 \leq n \leq 10^5,|x|, |y| \leq 10^9\)。

对于40% 的数据,满足\(1 \leq n \leq 10^2,|x|, |y| \leq 10^2\)。

对于以上每部分数据,都有50% 的数据n 是奇数。

注意数据范围是x 和y 的绝对值,x 和y 可以是负数。

分析

题目中描述的距离就是切比雪夫距离,转化为曼哈顿距离后发现,要求的就是找一个点\((x,y)\)使得

\[\sum_{i=1}^n(|x-x_i|+|y-y_i|) \\
= \sum_{i=1}^n|x-x_i| + \sum_{i=1}^n|y-y_i|
\]

最小。

显然应该选取xi和yi的中位数。

程序实现的时候把曼哈顿距离下的点横纵坐标都乘2,方便判断小数部分是不是0.5。

但是有问题,就是选出来的在曼哈顿距离下是整点,但在切比雪夫距离下不一定是整点。

所以需要分类讨论。

  1. 能选的只有一个点,但这个点不是整点,所以要想四周抖动。
  2. 能选的是一个范围,所以要奇偶配对。

代码

  1. #include<cstdlib>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<cstring>
  5. #include<iostream>
  6. #include<string>
  7. #include<vector>
  8. #include<list>
  9. #include<deque>
  10. #include<stack>
  11. #include<queue>
  12. #include<map>
  13. #include<set>
  14. #include<bitset>
  15. #include<algorithm>
  16. #include<complex>
  17. #include<cassert>
  18. #define rg register
  19. #define il inline
  20. #define co const
  21. #pragma GCC optimize ("O0")
  22. using namespace std;
  23. template<class T> il T read()
  24. {
  25. T data=0;
  26. int w=1;
  27. char ch=getchar();
  28. while(!isdigit(ch))
  29. {
  30. if(ch=='-')
  31. w=-1;
  32. ch=getchar();
  33. }
  34. while(isdigit(ch))
  35. data=10*data+ch-'0',ch=getchar();
  36. return data*w;
  37. }
  38. template<class T> il T read(T&x)
  39. {
  40. return x=read<T>();
  41. }
  42. typedef long long ll;
  43. const int INF=0x7fffffff;
  44. const int MAXN=1e5+7;
  45. int n;
  46. ll x[MAXN],y[MAXN];
  47. ll ans,cnt;
  48. void calc(ll x,ll y)
  49. {
  50. ll t=0;
  51. for(int i=0;i<n;++i)
  52. {
  53. t+=abs(::x[i]-x)+abs(::y[i]-y);
  54. }
  55. if(ans>t)
  56. {
  57. ans=t;
  58. cnt=1;
  59. }
  60. else if(ans==t)
  61. {
  62. ++cnt;
  63. }
  64. }
  65. ll odd(ll L,ll R)
  66. {
  67. ll t=R-L+1;
  68. if((L&1)&&(R&1))
  69. {
  70. t=(t+1)/2;
  71. }
  72. else
  73. {
  74. t/=2;
  75. }
  76. return t;
  77. }
  78. ll even(ll L,ll R)
  79. {
  80. ll t=R-L+1;
  81. if(L%2==0&&R%2==0)
  82. {
  83. t=(t+1)/2;
  84. }
  85. else
  86. {
  87. t/=2;
  88. }
  89. return t;
  90. }
  91. void solve(ll x1,ll x2,ll y1,ll y2)
  92. {
  93. if(x1==x2&&y1==y2&&(x1+y1)&1)
  94. {
  95. calc(x1-1,y1);
  96. calc(x1+1,y1);
  97. calc(x1,y1-1);
  98. calc(x1,y1+1);
  99. assert(ans%2==0);
  100. }
  101. else
  102. {
  103. calc(x1,y1);
  104. cnt=odd(x1,x2)*odd(y1,y2)+even(x1,x2)*even(y1,y2);
  105. assert(ans%2==0);
  106. }
  107. }
  108. int main()
  109. {
  110. freopen("zhengzhou.in","r",stdin);
  111. freopen("zhengzhou.out","w",stdout);
  112. read(n);
  113. for(int i=0;i<n;++i)
  114. {
  115. ll x=read<ll>(),y=read<ll>();
  116. ::x[i]=x+y,::y[i]=x-y; // *2
  117. }
  118. sort(x,x+n);
  119. sort(y,y+n);
  120. ans=1e18;
  121. solve(x[(n-1)/2],x[n/2],y[(n-1)/2],y[n/2]);
  122. printf("%lld\n%lld\n",ans/2,cnt);
  123. // fclose(stdin);
  124. // fclose(stdout);
  125. return 0;
  126. }

test20181015 B 君的第三题的更多相关文章

  1. test20181016 B君的第三题

    题意 B 君的第三题(haskell) 题目描述 大学四年,我为什么,为什么不好好读书,没找到和你一样的工作. B 君某天看到了这样一个题,勾起了无穷的回忆. 输入\(n, k\) 和一棵\(n\) ...

  2. test20181018 B君的第三题

    题意 B 君的第三题(shenyang) 题目描述 客似云来,万里无云 B 君得到了一个数组\(\{a_1,a_2,\dots,a_n\}\). B 君想通过修改让数组中个每对数都互质. 每次使一个数 ...

  3. test20181019 B君的第三题

    题意 B 君的第三题(urumqi) 题目描述 风雨如晦,鸡鸣不已. B 君最近在研究自己的学长都在做什么工作,每个学长属于一个公司. B 君会获得一些信息,比如x 和y 在相同公司,x 和y 在不同 ...

  4. noiac132 B君的第三题 (树形dp)

    传送门 本来想用点分治做,结果root又求不对 算的时候还算错了 我好菜啊 结果szr大佬告诉我是树形dp 我好菜啊!! 我们有$\lceil \frac{x}{k} \rceil = \frac{x ...

  5. shanquan2的两年三题系列

    好像只有2个月就退役啦 不管了,先说一下哪三题:多点求值.lcm.替罪羊树(bzoj3065) [upd0]2016.3.29 多点求值A掉啦,myy卡常数sxbk(不是说好的是shanquan2出的 ...

  6. Java-集合-第三题 有如下Student 对象, private String name; private int age; private int score; private String classNum; 其中,classNum 表示学生的班号,例如“class05”。 有如下List List list = new ArrayList(); l

    第三题 有如下Student 对象, private String name; private int age; private int score; private String classNum; ...

  7. NOIP 2008提高组第三题题解by rLq

    啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...

  8. NOIP2008提高组(前三题) -SilverN

    此处为前三题,第四题将单独发布 火柴棒等式 题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0 ...

  9. 《学习OpenCV》练习题第四章第三题b

    #include <highgui.h> #include <cv.h> #include "opencv_libs.h" /* *<学习OpenCV ...

随机推荐

  1. Entity Framework Code First在Oracle下的伪实现(转)

    为什么要说是伪实现,因为还做不到类似MsSql中那样完全的功能.Oralce中的数据库还是要我们自己手动去创建的.这里,我们舍掉了Model First中的EDMX文件,自己在代码里面写模型与映射关系 ...

  2. [one day one question] iphone6 plus h5页面滑动莫名卡

    问题描述: iphone6 plus h5页面滑动莫名卡,这怎么破? 解决方案: 比较奇葩的问题,在找不到任何问题的情况下,可以考虑在下发现的解决方案,html,body未添加height: 100% ...

  3. jz2440-uboot-201204版本移植【学习笔记】【原创】

    平台:jz2440 作者:庄泽彬(欢迎转载,请注明作者) 说明:韦东山二期视频学习笔记 交叉编译工具:arm-linux-gcc (GCC)4.3.2 PC环境:ubuntu18.04 一.uboot ...

  4. ubuntu 16.04下更换源和pip源【转】

    本文转载自:https://blog.csdn.net/weixin_41500849/article/details/80246221 写在前面的话 本文主要内容是更换系统源为清华大学源,更换pyt ...

  5. Net Quartz使用

    安装Quartz 已经先安装了2.5版本,现在换成2.4 程序包管理器控制台: PM> Install-Package Quartz -Version 2.4 正在尝试收集与目标为“.NETFr ...

  6. pyenv 让 python 版本完美切换

    前言 我觉得如果使用 python 开发的话,还是在 unix/linux 的环境下吧,shell 工具的效率比 windows 高得多,尽管 windows 下也有 cmder 这种神器,而且现在 ...

  7. c语言 找最小值

    #include <stdio.h> #define N 10 #define MIN(X,Y) ((X<Y)?(X):(Y)) int f(int arr[],int len,in ...

  8. 一次完整的HTTP事务是怎样一个过程

    当我们在浏览器的地址栏输入 www.linux178.com,然后回车,回车这一瞬间到看到页面到底发生了什么呢? 以下过程仅是个人理解: 域名解析 --> 发起TCP的3次握手 --> 建 ...

  9. Vue.js的类Class 与属性 Style如何绑定

    Vue.js的类Class 与属性 Style如何绑定 一.总结 一句话总结:数据绑定一个常见需求是操作元素的 class 列表和它的内联样式.因为它们都是属性,我们可以用 v-bind 处理它们:我 ...

  10. 雷林鹏分享:JSP 开发环境搭建

    JSP 开发环境搭建 JSP开发环境是您用来开发.测试和运行JSP程序的地方. 本节将会带您搭建JSP开发环境,具体包括以下几个步骤. 配置Java开发工具(JDK) 这一步涉及Java SDK的下载 ...