[COCI2015]COCI

题目大意:

有\(n(n\le5\times10^5)\)个人比赛,比赛总共进行\(3\)轮,每一轮得分为\([0,650]\)内的整数。现在已经得知每个人前两轮的成绩。若规定一个人\(A\)在前两轮的成绩均严格高于\(B\),则\(A\)在第\(3\)轮的成绩也一定高于\(B\)。求每个人在比赛完成后,最高及最低的可能排名。

思路:

以最高排名为例,对于人\(A\)来言,若\(B\)在前两轮得分的总和\(-A\)在前两轮得分的总和\(\ge 650\),则无论如何,\(A\)都没有再次超过\(B\)的可能。

剩下我们则需要统计与\(A\)两轮得分差值不超过\(650\),但是又全面碾压\(A\)的人的个数。这显然是一个二维数点问题,用二维树状数组解决即可。

时间复杂度\(\mathcal O(n\log^2650)\)。

源代码:

#include<cstdio>
#include<cctype>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=5e5+1,M=652;
struct Player {
int a,b,id;
int total() const {
return a+b;
}
bool operator < (const Player &rhs) const {
return total()<rhs.total();
}
};
Player p[N];
class FenwickTree1 {
private:
int val[M][M];
int lowbit(const int &x) const {
return x&-x;
}
public:
void modify(int p,const int &q,const int &x) {
for(;p;p-=lowbit(p)) {
for(register int j=q;j;j-=lowbit(j)) {
val[p][j]+=x;
}
}
}
int query(int p,const int &q) {
int ret=0;
for(;p<M;p+=lowbit(p)) {
for(register int j=q;j<M;j+=lowbit(j)) {
ret+=val[p][j];
}
}
return ret;
}
};
FenwickTree1 t1;
class FenwickTree2 {
private:
int val[M][M];
int lowbit(const int &x) const {
return x&-x;
}
public:
void modify(int p,int q,const int &x) {
for(p++,q++;p<M;p+=lowbit(p)) {
for(register int j=q;j<M;j+=lowbit(j)) {
val[p][j]+=x;
}
}
}
int query(int p,int q) {
int ret=0;
for(p++,q++;p;p-=lowbit(p)) {
for(register int j=q;j;j-=lowbit(j)) {
ret+=val[p][j];
}
}
return ret;
}
};
FenwickTree2 t2;
int max[N],min[N];
int main() {
const int n=getint();
for(register int i=1;i<=n;i++) {
p[i].a=getint();
p[i].b=getint();
p[i].id=i;
}
std::sort(&p[1],&p[n]+1);
for(register int i=1,j=1;i<=n;i++) {
for(;j<=n&&p[j].total()-p[i].total()<=650;j++) {
t1.modify(p[j].a,p[j].b,1);
}
max[p[i].id]=n-j+1+t1.query(p[i].a+1,p[i].b+1);
t1.modify(p[i].a,p[i].b,-1);
}
std::reverse(&p[1],&p[n]+1);
for(register int i=1,j=1;i<=n;i++) {
for(;j<=n&&p[i].total()-p[j].total()<650;j++) {
t2.modify(p[j].a,p[j].b,1);
}
min[p[i].id]=n-(n-j+1+t2.query(p[i].a-1,p[i].b-1));
}
for(register int i=1;i<=n;i++) {
printf("%d %d\n",max[i]+1,min[i]);
}
return 0;
}

[COCI2015]COCI的更多相关文章

  1. [COCI]coci2015/2016 nekameleoni

    题意: 初始数列,每个数都在1~k以内 支持两种操作:1.修改一个数,修改后的数在1~k内                           2.查询一个最短包含1~k的序列的长度 查询100000 ...

  2. BZOJ3188: [Coci 2011]Upit

    3188: [Coci 2011]Upit Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 72  Solved: 24[Submit][Status] ...

  3. [SinGuLaRiTy] COCI 2016~2017 #5

    [SinGuLaRiTy-1012] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 最近神犇喜欢考COCI...... 测试题目 对于所有的 ...

  4. [SinGuLaRiTy] COCI 2011~2012 #2

    [SinGuLaRiTy-1008] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 测试题目 对于所有的题目:Time Limit:1s   ...

  5. BZOJ 3881: [Coci2015]Divljak [AC自动机 树链的并]

    3881: [Coci2015]Divljak 题意:添加新文本串,询问某个模式串在多少种文本串里出现过 模式串建AC自动机,考虑添加一个文本串,走到的节点记录下来求树链的并 方法是按dfs序排序去重 ...

  6. BZOJ3810: [Coci2015]Stanovi

    3810: [Coci2015]Stanovi Description Input 输入一行,三个整数,n, m, k   Output 输出一个数,表示最小不满意度.   Sample Input ...

  7. BZOJ_2223_[Coci 2009]PATULJCI_主席树

    BZOJ_2223_[Coci 2009]PATULJCI_主席树 Description Input 10 3 1 2 1 2 1 2 3 2 3 3 8 1 2 1 3 1 4 1 5 2 5 2 ...

  8. COCI 2018/2019 CONTEST #2 T4 Maja T5Sunčanje Solution

    COCI 2018/2019 CONTEST #2 T4 T5 Solution abstract 花式暴力 #2 T5 Sunčanje 题意 按顺序给你1e5个长方形(左下角坐标&& ...

  9. 【题解】 Luogu P4312 / SP4155 [COCI 2009] OTOCI / 极地旅行社

    原题地址:P4312 [COCI 2009] OTOCI / 极地旅行社/SP4155 OTOCI - OTOCI lct入门难度的题,十分弱智(小蒟蒻说lct是什么,能吃吗?) bridge操作判联 ...

随机推荐

  1. ajax请求数据时什么时候用GET,什么时候用POST

    GET的目的就如同其名字一样是用于获取信息的.它旨在显示出页面上你要阅读的信息.浏览器会缓冲GET请求的执行结果,如果同样的GET请求再次发出,浏览器就会显示缓冲的结果而不是重新运行整个请求.重新请求 ...

  2. 基于nginx的WebSocket反向代理

    系统:windows 版本:nginx 1.4.5 配置内容: location ~ \.do$ {             proxy_pass   http://192.168.20.102:80 ...

  3. VS和IIS的一些问题

    运行所有MVC一直502,重启了iis服务, 之后弹出这个框: 之后的解决办法: 1. If you open the applicationhost,config file in VS while ...

  4. java 数据类型相关的内容

    √基本数据默认值是:0 √ 引用类型是默认值:null 局部变量不能初始化 单精度浮点有后缀: Flong后面如果不加后缀L系统将默认为int类型 不管单精度还是双精度浮点,都比整数类型的范围大,原因 ...

  5. 跨域 jQuery库ajax请求

    XMLHttpRequest是原生ajax,缺点是使用起来比较繁琐. jQuery库提供了一组简洁的ajax请求方法. ajax() get() post() 具体使用参考官方API: http:// ...

  6. Sway

    啥是Sway: http://livesino.net/archives/7520.live 地址:http://sway.com 现在又可以申请了   试试效果

  7. 前端本地存储localStorage

    1.突破cookie 4K限制,一般浏览器支持5M 2.增 删 改 查 <!DOCTYPE html> <html lang="en"> <head& ...

  8. day10.函数进阶

    函数的命名空间 从python解释器开始执行之后,就在内存中开辟了一个空间,每当遇到一个变量的时候,就把变量名和值之间的对应关系记录下来. 但是当遇到函数定义的时候解释器只是象征性的将函数名读入内存, ...

  9. pyqt5界面使用

    安装配置了pyuic和pyrcc后再进行下面操作 1.打开:       位置(我的):C:\Users\AppData\Roaming\Python\Python35\site-packages\p ...

  10. sublime text 自定义插件,自动插入署名,自定义插入日期,自动生成头部注释

    自动插入署名 菜单下面的 一.工具(tool)>新代码段(new snippet…) 看到以下代码 <snippet> <content><![CDATA[ Hel ...