soldiers真乃神题也!

行列显然可以分开处理。

行好办,显然就是一个货仓选址问题,取中位数即可。

列呢??

??????

因为懒得推式子,用不了二分,我决定使用枚举大法!一算复杂度O(n^2),勉强可以卡过。

于是我做好了卡常数的准备,正在实现枚举及求值时,得到了援助:

你把士兵按照x排序,然后把x[i] - i即可转化为行上面的。

我略加思索:排好后是x[1], x[1] + 1, x[i] + 2, ..., x[i] + (i - 1)

那么我事先减去,便是x[1], x[1], x[1], ..., x[1]

妙啊,妙啊!

关于为何排序:使用了一点贪心的思想:如果一个A在B左边,那么排好队之后A也一定在B左边。

然后我抱着试一试的心态,过了样例,一口气AC了!!!


我们学到了什么?

转换:减去i

 #include <cstdio>
#include <algorithm>
#include <cstring>
using std::sort;
inline void read(int &x) {
x = ;
bool f = ;
char c = getchar();
while(c < '' || c > '') {
if(c == '-') {
f = ;
}
c = getchar();
}
while(c <= '' && c >= '') {
x = (x << ) + (x << ) + c - '';
c = getchar();
}
if(f) x = -x;
return;
}
inline void max(int &a, int b) {
if(a < b) a = b;
return;
}
inline void min(int &a, int b) {
if(a > b) a = b;
return;
}
inline int ab(int x) {
return (x < ) ? ((~x) + ) : x;
}
const int N = , INF = 0x7f7f7f7f; int x[N], y[N], n; int main() {
int lx = -INF, sx = INF;
int xx, yy;
read(n);
for(int i = ; i <= n; i++) {
read(x[i]);
read(y[i]);
} long long ans = ; ///solve y -> 1
sort(y + , y + n + );
int k = y[(n + ) >> ];
for(int i = ; i <= n; i++) {
ans += ab(y[i] - k);
} /// solve x -> []
sort(x + , x + n + );
for(int i = ; i <= n; i++) {
x[i] -= (i - );
}
sort(x + , x + n + );
k = x[(n + ) >> ];
for(int i = ; i <= n; i++) {
ans += ab(x[i] - k);
} printf("%lld", ans);
return ;
}

AC代码

poj1723 SOLDIERS的更多相关文章

  1. [POJ1723]SOLDIERS(中位数)

    题意 给出n个点的坐标,它们只能往上.下.左.右一格一格地移动,求使其移动至水平线上的最小步数. 思路 转载 先易后难,对于纵向的问题,我们推个公式,,这个很容易看出是货仓选址问题,k取y[i]的中位 ...

  2. POJ1723 SOLDIERS 兄弟连

    SOLDIERS 有一个性质:在一个长为n的序列a中找一个数 \(a_k\) 使得 \(\sum\limits_{i=1}^n abs(a_i-a_k)\) 最小,则 \(a_k\) 是a的中位数. ...

  3. POJ1723,1050,HDU4864题解(贪心)

    POJ1723 Soldiers 思维题. 考虑y坐标,简单的货舱选址问题,选择中位数即可. 再考虑x坐标,由于直接研究布置方法非常困难,可以倒着想:不管如何移动,最后的坐标总是相邻的,且根据贪心的思 ...

  4. $Poj1723/AcWing123\ Soldiers$ 排序

    $Poj$ $AcWing$ $Description$ $Sol$ 分别处理$x$坐标和$y$坐标.$y$坐标显然很好处理,就是排个序然后取中位数就好了.$x$没有$y$那么直接叭.所以我首先写了个 ...

  5. OpenJudge/Poj 1723 SOLDIERS

    1.链接地址: http://bailian.openjudge.cn/practice/1723/ http://poj.org/problem?id=1723 2.题目: 总时间限制: 1000m ...

  6. [转]13 Hours: The Secret Soldiers of Benghazi

    转:http://www.imfdb.org/wiki/13_Hours:_The_Secret_Soldiers_of_Benghazi The following weapons were use ...

  7. hdu 4412 Sky Soldiers(区间DP)

    Sky Soldiers Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tot ...

  8. csu 1749: Soldiers ' Training(贪心)

    1749: Soldiers ' Training Time Limit: 1 Sec  Memory Limit: 512 MBSubmit: 37  Solved: 18[Submit][Stat ...

  9. POJ 1723 SOLDIERS

    SOLDIERS Time Limit: 1000ms Memory Limit: 10000KB This problem will be judged on PKU. Original ID: 1 ...

随机推荐

  1. Spring中使用Ehcache的方法和注意事项

    如何调用方法数据增加缓存 @Cacheable(value="MY_CACHE", key="'cache_business_' + #business_id" ...

  2. spring 启动脚本分析

    参考:JVM 参数使用总结 参考:java  -Xms -Xmx -XX:PermSize -XX:MaxPermSize 参考:JVM调优总结 -Xms -Xmx -Xmn -Xss 参考:JAVA ...

  3. 老男孩python学习自修第六天【pycharm的使用】

    1.在工程右键可选新建文件夹,包盒python文件 文件夹和包的区别在于,包包含一个空的__init__.py文件,而文件夹没有 2.pycharm的断点调试 点击Debug表示进入调试状态 点击Re ...

  4. 一、纯css实现顶部进度条随滚动条滚动

    一.效果图 二.直接复制粘贴 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  5. chrome中 GET /undefined 404

    Chrome中调试网站,会出现 这是由 crxMouse Chrome™ 手势 引起的,关闭即可

  6. react 入坑笔记(五) - 条件渲染和列表渲染

    条件渲染和列表渲染 一.条件渲染 条件渲染较简单,使用 JavaScript 操作符 if 或条件运算符来创建表示当前状态的元素,然后让 React 根据它们来更新 UI. 贴一个小栗子: funct ...

  7. ExportHandler.ashx

    using KYZWeb.Common;using Liger.Data;//using Microsoft.Office.Interop.Excel;using System;using Syste ...

  8. Vue入门基础

    前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...

  9. Nginx stream ssl

    L 115 端口监听 netstat -anp | (端口名)

  10. Nginx+Tomcat 负载均衡集群

    案例分析 通常情况下,一台Tomcat站点由于可能出现单点故障及无法应对多客户复杂多样性的请求等问题,不能单独应用于生产环境下,所以我们需要一套更可靠的解决方案来完善Web站点架构. Nginx是一款 ...