poj1723 SOLDIERS
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的更多相关文章
- [POJ1723]SOLDIERS(中位数)
题意 给出n个点的坐标,它们只能往上.下.左.右一格一格地移动,求使其移动至水平线上的最小步数. 思路 转载 先易后难,对于纵向的问题,我们推个公式,,这个很容易看出是货仓选址问题,k取y[i]的中位 ...
- POJ1723 SOLDIERS 兄弟连
SOLDIERS 有一个性质:在一个长为n的序列a中找一个数 \(a_k\) 使得 \(\sum\limits_{i=1}^n abs(a_i-a_k)\) 最小,则 \(a_k\) 是a的中位数. ...
- POJ1723,1050,HDU4864题解(贪心)
POJ1723 Soldiers 思维题. 考虑y坐标,简单的货舱选址问题,选择中位数即可. 再考虑x坐标,由于直接研究布置方法非常困难,可以倒着想:不管如何移动,最后的坐标总是相邻的,且根据贪心的思 ...
- $Poj1723/AcWing123\ Soldiers$ 排序
$Poj$ $AcWing$ $Description$ $Sol$ 分别处理$x$坐标和$y$坐标.$y$坐标显然很好处理,就是排个序然后取中位数就好了.$x$没有$y$那么直接叭.所以我首先写了个 ...
- OpenJudge/Poj 1723 SOLDIERS
1.链接地址: http://bailian.openjudge.cn/practice/1723/ http://poj.org/problem?id=1723 2.题目: 总时间限制: 1000m ...
- [转]13 Hours: The Secret Soldiers of Benghazi
转:http://www.imfdb.org/wiki/13_Hours:_The_Secret_Soldiers_of_Benghazi The following weapons were use ...
- hdu 4412 Sky Soldiers(区间DP)
Sky Soldiers Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...
- csu 1749: Soldiers ' Training(贪心)
1749: Soldiers ' Training Time Limit: 1 Sec Memory Limit: 512 MBSubmit: 37 Solved: 18[Submit][Stat ...
- POJ 1723 SOLDIERS
SOLDIERS Time Limit: 1000ms Memory Limit: 10000KB This problem will be judged on PKU. Original ID: 1 ...
随机推荐
- php变量详解
变量是用于存储信息的"容器". 定义一个变量的语法: $变量名 = 值; 使用变量的例子: <?php $x=5; $y=6; $z=$x+$y; echo $z; ?> ...
- VMWARE中NAT下获取不到IP
1.编辑-虚拟网络编辑器-dhcp设置 2.虚拟机-可移动设备-网络适配器-设置,注意:这里一定要选nat,当初我就是选了桥接,死活上不去,搞了2个小时.
- MyBatis映射文件5
返回map Map<String,Object> getEmpByResMap(Integer id); <select id="getEmpByResMap&qu ...
- Ubuntu18.04安装mysql5.7
Ubuntu18.04安装mysql5.7 1.1安装 首先执行下面三条命令: # 安装mysql服务 sudo apt-get install mysql-server # 安装客户端 sudo a ...
- java 调用 wsdl形式的webservice 示例
import java.rmi.RemoteException; import javax.xml.rpc.ParameterMode; import javax.xml.rpc.ServiceExc ...
- todo项目总结
vue+webpack项目工程配置 1.vue-loader+webpack项目配置 2.webpack配置项目加载各种静态资源 3.webpack-dev-server的配置和使用 安装: pack ...
- html5 服務器發送事件
html5允許頁面獲得來自服務器的更新. 單項消息傳送: 頁面獲得服務器的更新. 以前頁面也可以獲得服務器的更新,但必須詢問服務器是否有可用的更新,而服務器發送事件是單向自動發送. 使用服務器發送事件 ...
- HTML 中的 href\src\url
1. 2. -------from Stack Overflow <a><link>使用 href; <img><script>使用 src;
- Atcoder Beginner Contest 118 D-Match Matching(完全背包)
题目链接 题意就是给N根火柴,M个数(M只能是1到9,对应的数字也只能是1到9),只能用这M个出现过的数(但每个数可以随便用多少个,只要火柴够)来拼出一个数字(拼出1,2,3,4,5,6,7,8,9分 ...
- Nginx 如何处理上游响应的数据
陶辉93 一个非常重要的指令 proxy_buffer_size 指令限制头部响应header最大值 proxy_buffering 指令主要是指 上游服务器是否接受完完整包体在处理 默认是on 也就 ...