题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4068

题意:吃鸡游戏简化为二维平面上有 n 个人 (xi,yi),空投的位置在 (x0,y0),每一秒所有人向靠近空投的位置走一步,四个方向有优先级先后(优先纵坐标),若已经在空投的位置则不变。往空投位置移动过程中,若两个或者更多人在同一点相遇(在空投相遇不算),则他们都死亡。给出空投的纵坐标,询问空投在所有横坐标中最少和最多存活的人数是多少。

题解:在最优情况下,空投的横坐标必然是某一个人的横坐标,因为这样可以保证在该横坐标的人都不会死亡;而在最坏情况下,空投的横坐标则在两个不同横坐标的人之间,若所有人横坐标都相差1,则空投横坐标也是某一个人的横坐标,所以需要考虑的横坐标最多只有 2n 个。把横坐标排序后,分别从左往右扫一遍记录每个点左边存活的人数和从右往左扫一遍每个点右边存活的人数即可,具体看代码~

 #include <bits/stdc++.h>
using namespace std;
#define ll long long
#define ull unsigned long long
#define mst(a,b) memset((a),(b),sizeof(a))
#define mp(a,b) make_pair(a,b)
#define pi acos(-1)
#define pii pair<int,int>
#define pb push_back
const int INF = 0x3f3f3f3f;
const double eps = 1e-;
const int MAXN = 1e5 + ;
const int MAXM = 2e5 + ;
const ll mod = 1e9 + ; int x[MAXN],y[MAXN];
vector<int>p,vec[MAXN],ans;
int num[MAXM],sum[MAXM]; int main() {
#ifdef local
freopen("data.txt", "r", stdin);
// freopen("data.txt", "w", stdout);
#endif
int t;
scanf("%d",&t);
while(t--) {
int n,y0;
scanf("%d%d",&n,&y0);
p.clear();
p.push_back();
for(int i = ; i <= n; i++) {
scanf("%d%d",&x[i],&y[i]);
vec[x[i]].clear();
vec[x[i] + ].clear();
p.push_back(x[i]);
p.push_back(x[i] + );
}
sort(p.begin(),p.end());
p.erase(unique(p.begin(),p.end()),p.end());
for(int i = ; i <= n; i++) vec[x[i]].push_back(y[i]);
int cnt = , pre = ;
mst(sum, );
mst(num, );
for(int i = ; i < p.size(); i++) {
int nx = p[i];
sum[nx] = vec[nx].size();
vector<int>temp;
for(int j = ; j < vec[pre].size(); j++) {
int k = abs(1e5 + - pre) + abs(y0 - vec[pre][j]);
num[k]++;
if(num[k] == ) cnt++;
else temp.push_back(k);
}
for(int j = ; j < temp.size(); j++) {
if(num[temp[j]]) cnt--;
num[temp[j]] = ;
}
sum[nx] += cnt;
pre = p[i];
}
ans.clear();
mst(num, );
pre = cnt = ;
for(int i = p.size() - ; i >= ; i--) {
int nx = p[i];
vector<int>temp;
for(int j = ; j < vec[pre].size(); j++) {
int k = abs( - pre) + abs(y0 - vec[pre][j]);
num[k]++;
if(num[k] == ) cnt++;
else temp.push_back(k);
}
for(int j = ; j < temp.size(); j++) {
if(num[temp[j]]) cnt--;
num[temp[j]] = ;
}
sum[nx] += cnt;
ans.push_back(sum[nx]);
pre = p[i];
}
sort(ans.begin(),ans.end());
printf("%d %d\n",ans[],ans[ans.size() - ]);
}
return ;
}

最新文章

  1. fineui刷新父页面
  2. Three.js外部模型加载
  3. Vue2.X的状态管理vuex记录
  4. [UCSD白板题] Primitive Calculator
  5. 一些sql二
  6. 记录一些在用wcf的过程中走过的泥巴路 【第一篇】
  7. I Hate It(hdu1754)(线段树区间最大值)
  8. [ay原创作品]用wpf写了个模仿36Kr网站登录背景的效果
  9. zepto源码--classRE、maybeAddPx、children、defaultDisplay--学习笔记
  10. C++ cout cerr 和 clog 的区别
  11. Ubuntu桌面版与服务器版有什么不同?
  12. PHP &amp; JAVA 实现 PBKDF2 加密算法
  13. C++面试题一大波
  14. poj2443(简单的状态压缩)
  15. ThinkPHP框架的增删改
  16. wireshark 随笔
  17. 压缩感知重构算法之子空间追踪(SP)
  18. 【nodejs】安装browser-sync 遇到错误提示
  19. 积累一些不太常用的C/C++语言知识(不断更新)
  20. Matplotlib学习---用matplotlib画热图(heatmap)

热门文章

  1. 《ucore lab1 exercise2》实验报告
  2. google搜索设置,在新的窗口打开
  3. sqlite lib导入
  4. 开启 oracle 的闪回功能
  5. redis用法分析
  6. double check
  7. nginx 设置开机启动
  8. Django入门第一步:构建一个简单的Django项目
  9. SublimeText 3 常见快捷键
  10. ajax格式,转入后台