bzoj1227 P2154 [SDOI2009]虔诚的墓主人
组合数学+离散化+树状数组
先看题,结合样例分析,易得每个墓地的虔诚度=C(正左几棵,k)*C(正右几棵,k)*C(正上几棵,k)*C(正下几棵,k),如果任意一遍的棵树<k,则虔诚度=0。
所以我们可以预处理出C(w,k)。
再看数据范围:“对于100%的数据,满足1 ≤ N, M ≤ 1,000,000,000,0 ≤ xi ≤ N,0 ≤ yi ≤ M,1 ≤ W ≤ 100,000,1 ≤ k ≤ 10。”
对比一下 n,m 和 w 的大小,肯定要离散化。
排序离散化后,我们可以枚举。
按 x 坐标排序后,我们在枚举时可以方便的得出C(正上几棵,k)*C(正下几棵,k)
但是 C(正左几棵,k)*C(正右几棵,k) 和 y 坐标有关系,是动态变化的。
所以我们可以用树状数组维护正左几棵,正右几棵。
然后注意一些细节:2147483648 在我的编译器有警告qaq,所以只能直接用 2147483648ll 了qwq
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cctype>
using namespace std;
inline int Int(){
char c=getchar(); int x=;
while(!isdigit(c)) c=getchar();
while(isdigit(c)) x=(x<<)+(x<<)+(c^),c=getchar();
return x;
}
inline int min(int &a,int &b) {return a<b ?a:b;}
const int maxw=1e5+;
struct data{int x,y;} a[maxw];
inline bool cmp1(const data &x0,const data &x1){return x0.x<x1.x||(x0.x==x1.x&&x0.y<x1.y);}
inline bool cmp2(const data &x0,const data &x1){return x0.y<x1.y||(x0.y==x1.y&&x0.x<x1.x);}
int n,m,w,k,ed,ans,c[maxw][],tmp[maxw],totx[maxw],toty[maxw],p[maxw],sum[maxw],last[maxw];
inline void add(int x,int y){for(;x<=ed;x+=(x&-x)) sum[x]+=y;}
inline int query(int x) {int ans=; for(;x;x-=(x&-x)) ans+=sum[x]; return ans;}
int main(){
n=Int(); m=Int(); w=Int();
for(int i=;i<=w;++i) a[i].x=Int(),a[i].y=Int();
k=Int(); int cnt; for(int i=;i<=w;++i) c[i][]=;
for(int i=;i<=w;++i)
for(int j=;j<=min(i,k);++j)
c[i][j]=c[i-][j]+c[i-][j-];
//预处理组合数
sort(a+,a+w+,cmp1); cnt=; tmp[]=;
for(int i=;i<=w;++i) cnt= a[i].x==a[i-].x ? cnt:cnt+,tmp[i]=cnt;
for(int i=;i<=w;++i) ++totx[a[i].x=tmp[i]];
sort(a+,a+w+,cmp2); cnt=; tmp[]=;
for(int i=;i<=w;++i) cnt= a[i].y==a[i-].y ? cnt:cnt+,tmp[i]=cnt;
for(int i=;i<=w;++i) ++toty[a[i].y=tmp[i]];
ed=a[w].y;
//横纵坐标离散化
sort(a+,a+w+,cmp1);
for(int i=;i<=w;++i){
cnt= i==||a[i].x!=a[i-].x ? :cnt+;
int u=a[i].y,v= (++p[u])>=k&&toty[u]-p[u]>=k ? 1LL*c[p[u]][k]*c[toty[u]-p[u]][k]%2147483648ll:;
add(u,v-last[u]); last[u]=v;
if(i==w||a[i].x!=a[i+].x||a[i+].y-a[i].y<=||cnt<k||totx[a[i].x]-cnt<k) continue;
ans+= 1LL*c[cnt][k]*c[totx[a[i].x]-cnt][k]%2147483648ll*(query(a[i+].y-)-query(a[i].y))%2147483648ll;
}//树状数组维护
printf("%d",ans< ?(ans+2147483648ll)%2147483648ll:ans);
return ;
}
bzoj1227 P2154 [SDOI2009]虔诚的墓主人的更多相关文章
- 【BZOJ1227】[SDOI2009]虔诚的墓主人(线段树)
[BZOJ1227][SDOI2009]虔诚的墓主人(线段树) 题面 BZOJ 洛谷 题解 显然发现答案就是对于每一个空位置,考虑上下左右各有多少棵树,然后就是这四个方向上树的数量中选\(K\)棵出来 ...
- 【BZOJ1227】[SDOI2009]虔诚的墓主人
E. 虔诚的墓主人 题目描述 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地.当地的居民都是非常虔诚的基督徒,他们愿意提前 ...
- 【bzoj1227】 SDOI2009—虔诚的墓主人
http://www.lydsy.com/JudgeOnline/problem.php?id=1227 (题目链接) 题意 一个n*m的公墓,一个点上要么是墓地,要么是常青树,给出一个数K,并规定每 ...
- P2154 [SDOI2009]虔诚的墓主人 树状数组
https://www.luogu.org/problemnew/show/P2154 题意 在一个坐标系中,有w(1e5)个点,这个图中空点的权值是正上,正下,正左,正右各取k个的排列组合情况.计算 ...
- [洛谷P2154] SDOI2009 虔诚的墓主人
问题描述 小W是一片新造公墓的管理人.公墓可以看成一块N×M的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. 当地的居民都是非常虔诚的基督徒,他们愿意提前为自己找一块合适墓地. ...
- P2154 [SDOI2009]虔诚的墓主人
略有一点点思维的题. 首先,如果一个点上,下,左,右分别有\(a,b,c,d\)棵树,那这个点的十字架方案为\(C_{a}^{k}C_{b}^{k}C_{c}^{k}C_{d}^{k}\). 按x坐标 ...
- luogu P2154 [SDOI2009]虔诚的墓主人
luogu 下面记一个点上下左右点数分别为\(u_i,d_i,l_i,r_i\) 枚举每个中间点太慢了,考虑枚举两个点之间横的一条线段,这里面的点左边点数目都相同,右边点数目都相同,然后只要查一下区间 ...
- BZOJ1227 SDOI2009 虔诚的墓主人【树状数组+组合数】【好题】*
BZOJ1227 SDOI2009 虔诚的墓主人 Description 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. ...
- bzoj1227 [SDOI2009]虔诚的墓主人(组合公式+离散化+线段树)
1227: [SDOI2009]虔诚的墓主人 Time Limit: 5 Sec Memory Limit: 259 MBSubmit: 803 Solved: 372[Submit][Statu ...
随机推荐
- 致敬金庸:武侠版编程语言...Java像张无忌还是令狐冲?
我就喜欢这样,等新闻消失,热点过去,人们快要遗忘的时候, 用自己的方式,想起他.让他被人想起. 短评:夫千里之远,不足以举其大:千仞之高,不足以举其深.<倚天屠龙记> 短评:这世间和张三丰 ...
- MongoDB--搭建mongodb服务器
此为手动搭建: 可以看到初始化data时所有的数据,和log里已经有日志文件
- ROSETTA使用技巧随笔--蛋白蛋白对接
先写简略版,以后再详细写. 1. 对输入结构进行预处理(refine) $> relax.default.linuxgccrelease -in:file:s input_files/from_ ...
- python更新zip文件中文件
#更新zip文件中某一个文件import os import shutil import tempfile import zipfile from rat_tool.pack import * too ...
- echarts实现全国地图
1.首先我没有按需引入echarts,我是全局引入的,所以说在node_modules中有 这个china,你只需要在你的页面引入即可 但是按需引入echarts 的 项目中node_modules中 ...
- sourceInsight工具移除不掉项目 source Insight Add and Remove Project Files
问题描述: sourceInsight创建的项目,有时候会遇到Remove Project 报错,移除不成功的情况. 解决办法: 进入到sourceinsight的安装目录.删除掉保存的工程文件信息即 ...
- eclipse中tomcat启动成功,浏览器访问失败
eclipse添加tomcat之后,tomcat有个默认设置,我们需要对tomcat进行重新设置: 1.双击已添加的tomcat,进入到配置页面,找到server locations一栏,可以看到默认 ...
- featuremap尺寸的计算
对于卷积层,向下取整 对于池化层:想上取整 output=((input+2*pad-dilation*(kernel-1)+1)/stride)+1 input:输入尺寸 output:输出尺寸 p ...
- 软工网络15团队作业4——Alpha阶段敏捷冲刺3.0
软工网络15团队作业4--Alpha阶段敏捷冲刺3.0 1.每天举行站立式会议,提供当天站立式会议照片一张. 2.项目每个成员的昨天进展.存在问题.今天安排. 成员 昨天已完成 今天计划完成 郭炜埕 ...
- object base基类分析
uvm_object,是所有uvm data和hierarchical class的基类,实现了copy,compare,print,record之类的函数 扩展类中必须实现create和get_ty ...