【问题描述】

卡普地公司举办了「世界第一的猛汉王」全球大会,来自世界各地的猛汉为了争夺「猛汉王」的名号前来一决高下。现在举行的是弓箭组选拔赛。卡普地公司为比赛新建了一张PVP地图——「猛汉竞技场」。有许多使用弓的猛汉在这里互相较量。他们中的一些装填了「接击瓶」,这使得他们在接近战中会占有一定优势,但是在远程战中会相当劣势。具体来说如下:

假设q装填了「接击瓶」而p没有,则当他们的曼哈顿距离大于D时,p压制q,反之q压制p。如果pq都装填了「接击瓶」或者都没有,则他们之间仍然会存在一个客观上的单向压制关系,但是在比赛刚开始时无法得知。

竞技场上一共有n+m个猛汉,其中n个装填了「接击瓶」,另外m个没有。每个猛汉降临到竞技场时有一个坐标(x, y)。Mark Douglas作为上一届的猛汉王正在观看这场比赛,他希望得知场上有多少个「猛汉三角」。「猛汉三角」是指三个人uvw满足u压制vv压制ww压制u,且三人中至少有一人装填了「接击瓶」且至少有一人没有。由于场上尚存在一些不明了的压制关系,所以Mark希望知道可能的「猛汉三角」数量的最小值和最大值。

【输入格式】

输入文件名为mhw.in

输入第一行为三个正整数n m D

接下来n行每行两个正整数x y,表示装填了「接击瓶」的猛汉的坐标。

接下来m行每行两个正整数x y,表示没有装填「接击瓶」的猛汉的坐标。

可能有多个猛汉站在同一个位置。

【输出格式】

输出文件名为mhw.out

输出两个数min max,表示答案的最小值和最大值。

【样例输入与输出】

example_mhw1.in

example_mhw1.out

2 2 1

1 2

1 1

3 1

2 2

0 2

难度确实大!

首先我们将猛汉们分为两个阵营(记为黑色与白色)。我们一个猛汉三角就是形如a->c->b(a,b同阵营),然后在确定a,b之间的压制关系得到最小或者最大值。

我们以白色阵营为例。我们设cover[v]为v压制的对方阵营的数量,cover[v,u]为v,u共同压制的对方阵营的数量。maxans同理。

。对于cover[v,u],我们就算另一方阵营对的贡献就行了。如果一个猛汉被对面的k个人压制,那么他对的贡献就是

求cover数组可以用扫描+线段树。

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<ctime>
#include<queue>
#define ll long long
#define N 100005 using namespace std;
inline ll Get() {ll x=,f=;char ch=getchar();while(ch<''||ch>'') {if(ch=='-') f=-;ch=getchar();}while(''<=ch&&ch<='') {x=(x<<)+(x<<)+ch-'';ch=getchar();}return x*f;} ll n,m,lim;
ll mn,mx;
ll cc;
ll d[N*];
ll cnt;
ll c[][N]; struct line {
ll x,op,col,id;
ll l,r;
bool operator <(const line &a)const {
if(x!=a.x) return x<a.x;
return op<a.op;
}
}st[N*]; struct tree {
ll l,r;
ll sum[];
}tr[N*]; void build(ll v,ll l,ll r) {
tr[v].l=l,tr[v].r=r;
if(l==r) return ;
ll mid=l+r>>;
build(v<<,l,mid),build(v<<|,mid+,r);
} void Modify(ll v,ll l,ll r,ll tag,ll f) {
if(tr[v].l>r||tr[v].r<l) return ;
if(l<=tr[v].l&&tr[v].r<=r) {
tr[v].sum[tag]+=f;
return ;
}
Modify(v<<,l,r,tag,f),Modify(v<<|,l,r,tag,f);
} ll query(ll v,ll pos,ll tag) {
if(tr[v].l>pos||tr[v].r<pos) return ;
if(tr[v].l==tr[v].r) return tr[v].sum[tag];
return query(v<<,pos,tag)+query(v<<|,pos,tag)+tr[v].sum[tag];
} void work() {
for(ll i=;i<=cnt;i++) {
if(st[i].op==-) {
Modify(,st[i].l,st[i].r,st[i].col,);
} else if(st[i].op==) {
c[st[i].col][st[i].id]=query(,st[i].l,st[i].col^);
} else {
Modify(,st[i].l,st[i].r,st[i].col,-);
}
}
} int main() {
n=Get(),m=Get(),lim=Get();
ll a,b,x,y;
for(ll i=;i<=n;i++) {
a=Get(),b=Get();
x=a+b,y=a-b;
st[++cnt]=(line) {x-lim,-,,i,y-lim,y+lim};
st[++cnt]=(line) {x,,,i,y};
st[++cnt]=(line) {x+lim,,,i,y-lim,y+lim};
d[++d[]]=y;
d[++d[]]=y+lim;
d[++d[]]=y-lim;
}
for(ll i=;i<=m;i++) {
a=Get(),b=Get();
x=a+b,y=a-b;
st[++cnt]=(line) {x-lim,-,,i,y-lim,y+lim};
st[++cnt]=(line) {x,,,i,y};
st[++cnt]=(line) {x+lim,,,i,y-lim,y+lim};
d[++d[]]=y;
d[++d[]]=y+lim;
d[++d[]]=y-lim;
}
sort(st+,st++cnt);
sort(d+,d++d[]);
cc=unique(d+,d++d[])-d;
for(ll i=;i<=cnt;i++) {
st[i].l=lower_bound(d+,d+cc,st[i].l)-d;
st[i].r=lower_bound(d+,d+cc,st[i].r)-d;
}
build(,,cc); work();
for(ll i=;i<=m;i++) c[][i]=n-c[][i];
sort(c[]+,c[]++n);
sort(c[]+,c[]++m); for(ll i=;i<=n;i++) {
mn+=(n-i)*c[][i];
mx+=(i-)*c[][i];
ll x=1ll*(m-c[][i])*(m-c[][i]-)/;
mn-=x,mx-=x;
}
for(ll i=;i<=m;i++) {
mn+=1ll*(m-i)*c[][i];
mx+=1ll*(i-)*c[][i];
ll x=1ll*(n-c[][i])*(n-c[][i]-)/;
mn-=x,mx-=x;
}
cout<<mn<<" "<<mx;
return ;
}

【九校3D2T3】世界第一的猛汉王的更多相关文章

  1. test20180922 世界第一的猛汉王

    题意 分析 由于异色点必有连边,所以一个点的covered减去两个点共有的covered就是可存在的环数,十分巧妙. 代码 #include <bits/stdc++.h> using L ...

  2. 九校联考 终&启

    one term's ending... class:12 school:130...130...130... 至今没有看到九校的排名,如果九校排名正常的话,那yyhs的学生也太可怕了...估计要三百 ...

  3. 中国人被“清朝GDP世界第一”忽悠了!

    中国人被"清朝GDP世界第一"忽悠了!"鸦片战争前的清朝GDP世界第一",这一说法在中国流传非常广.追根溯源,最早提出这一观点的似乎是英国学者麦迪森,他的一项猜 ...

  4. 牛客网 暑期ACM多校训练营(第一场)A.Monotonic Matrix-矩阵转化为格子路径的非降路径计数,Lindström-Gessel-Viennot引理-组合数学

    牛客网暑期ACM多校训练营(第一场) A.Monotonic Matrix 这个题就是给你一个n*m的矩阵,往里面填{0,1,2}这三种数,要求是Ai,j⩽Ai+1,j,Ai,j⩽Ai,j+1 ,问你 ...

  5. ZT:阿里合伙人发文:十年磨一剑,自研数据库终拿世界第一

    按:真正做技术的,就该这样. 以下为全文转载 (观察者网讯) 10月24日,阿里巴巴合伙人.高德总裁刘振飞在阿里云开发者社区发文,回忆从2009年启动“去IOE”工程到2019年OceanBase拿下 ...

  6. HDU6578 2019HDU多校训练赛第一场 1001 (dp)

    HDU6578 2019HDU多校训练赛第一场 1001 (dp) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6578 题意: 你有n个空需要去填,有 ...

  7. HDU6579 2019HDU多校训练赛第一场1002 (线性基)

    HDU6579 2019HDU多校训练赛第一场1002 (线性基) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题意: 两种操作 1.在序列末 ...

  8. 旷视6号员工范浩强:高二开始实习,“兼职”读姚班,25岁在CVPR斩获第四个世界第一...

    初来乍到,这个人说话容易让人觉得"狂". "我们将比赛结果提交上去,果不其然,是第一名的成绩."当他说出这句话的时候,表情没有一丝波澜,仿佛一切顺理成章. 他说 ...

  9. 天大福利!世界第一科技出版公司 Springer 免费开放 400 多本电子书!

    前几天,世界著名的科技期刊/图书出版公司施普林格(Springer)宣布:免费向公众开放 400 多本正版的电子书!! Springer 即施普林格出版社,于1842 年在德国柏林创立,20 世纪60 ...

随机推荐

  1. 【PyTorch深度学习60分钟快速入门 】Part3:神经网络

      神经网络可以通过使用torch.nn包来构建. 既然你已经了解了autograd,而nn依赖于autograd来定义模型并对其求微分.一个nn.Module包含多个网络层,以及一个返回输出的方法f ...

  2. 如何做自己的服务监控?spring boot 2.x服务监控揭秘

    Actuator是spring boot项目中非常强大一个功能,有助于对应用程序进行监视和管理,通过 restful api请求来监管.审计.收集应用的运行情况,针对微服务而言它是必不可少的一个环节. ...

  3. Nginx实战-后端应用健康检查

    严格来说,nginx是没有针对负载均衡后端节点的健康检查的,但是可以通过proxy_next_upstream来间接实现,但这个还是会把请求转发给故障服务器的,然后再转发给别的服务器,这样就浪费了一次 ...

  4. WIN7 环境下搭建 PHP7(64 位)操作步骤

    WIN7 环境下搭建 PHP7(64 位)操作步骤 一.安装与配置 Apache 1.下载 Apache下载地址:https://www.apachelounge.com/download/ 2.安装 ...

  5. 正则表达式,re模块

    一,正则表达式 正则表达式是对字符串操作的一种逻辑公式,我们一般使用正则表达式对字符串进行匹配和过滤,使用正则的优缺点,我们可以去http://tool.chinaz.com/regex/进行测试. ...

  6. VB.NET语法小结

    本人精通C#编程,VB没有开发经验,项目维护需要,特意整理了下VB语法,进行恶补.编程思想都是互通的,都是微软生的,语言大同小异. Imports System 一.(1)定义一个变量,并且初始化. ...

  7. jquery中innerwidth,outerwidth,outerwidth和width的区别

    在jQuery中,width()方法用于获得元素宽度: innerWidth()方法用于获得包括内边界(padding)的元素宽度, outerWidth()方法用于获得包括内边界(padding)和 ...

  8. Gauss-Laguerre quadrature rule

    % matlab script to derive the 2-point Gauss-Laguerre quadrature rule % and use it on an example % in ...

  9. When should you use a class vs a struct in C++?

    Question: In what scenarios is it better to use a struct vs a class in C++? Answer: The only differe ...

  10. 如何把SVG小图片转换为 html字体图表

    自制作的简单字体图表使用案例:查看demo 制作步骤: 1:登录制作工具在线网站 https://icomoon.io/ 2:右上角红色 按钮进入到:https://icomoon.io/app/#/ ...