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

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. #include<cctype>
  6. using namespace std;
  7. inline int Int(){
  8. char c=getchar(); int x=;
  9. while(!isdigit(c)) c=getchar();
  10. while(isdigit(c)) x=(x<<)+(x<<)+(c^),c=getchar();
  11. return x;
  12. }
  13. inline int min(int &a,int &b) {return a<b ?a:b;}
  14. const int maxw=1e5+;
  15. struct data{int x,y;} a[maxw];
  16. inline bool cmp1(const data &x0,const data &x1){return x0.x<x1.x||(x0.x==x1.x&&x0.y<x1.y);}
  17. inline bool cmp2(const data &x0,const data &x1){return x0.y<x1.y||(x0.y==x1.y&&x0.x<x1.x);}
  18. int n,m,w,k,ed,ans,c[maxw][],tmp[maxw],totx[maxw],toty[maxw],p[maxw],sum[maxw],last[maxw];
  19. inline void add(int x,int y){for(;x<=ed;x+=(x&-x)) sum[x]+=y;}
  20. inline int query(int x) {int ans=; for(;x;x-=(x&-x)) ans+=sum[x]; return ans;}
  21. int main(){
  22. n=Int(); m=Int(); w=Int();
  23. for(int i=;i<=w;++i) a[i].x=Int(),a[i].y=Int();
  24. k=Int(); int cnt;
  25.  
  26. for(int i=;i<=w;++i) c[i][]=;
  27. for(int i=;i<=w;++i)
  28. for(int j=;j<=min(i,k);++j)
  29. c[i][j]=c[i-][j]+c[i-][j-];
  30. //预处理组合数
  31. sort(a+,a+w+,cmp1); cnt=; tmp[]=;
  32. for(int i=;i<=w;++i) cnt= a[i].x==a[i-].x ? cnt:cnt+,tmp[i]=cnt;
  33. for(int i=;i<=w;++i) ++totx[a[i].x=tmp[i]];
  34. sort(a+,a+w+,cmp2); cnt=; tmp[]=;
  35. for(int i=;i<=w;++i) cnt= a[i].y==a[i-].y ? cnt:cnt+,tmp[i]=cnt;
  36. for(int i=;i<=w;++i) ++toty[a[i].y=tmp[i]];
  37. ed=a[w].y;
  38. //横纵坐标离散化
  39. sort(a+,a+w+,cmp1);
  40. for(int i=;i<=w;++i){
  41. cnt= i==||a[i].x!=a[i-].x ? :cnt+;
  42. 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:;
  43. add(u,v-last[u]); last[u]=v;
  44. if(i==w||a[i].x!=a[i+].x||a[i+].y-a[i].y<=||cnt<k||totx[a[i].x]-cnt<k) continue;
  45. ans+= 1LL*c[cnt][k]*c[totx[a[i].x]-cnt][k]%2147483648ll*(query(a[i+].y-)-query(a[i].y))%2147483648ll;
  46. }//树状数组维护
  47. printf("%d",ans< ?(ans+2147483648ll)%2147483648ll:ans);
  48. return ;
  49. }

bzoj1227 P2154 [SDOI2009]虔诚的墓主人的更多相关文章

  1. 【BZOJ1227】[SDOI2009]虔诚的墓主人(线段树)

    [BZOJ1227][SDOI2009]虔诚的墓主人(线段树) 题面 BZOJ 洛谷 题解 显然发现答案就是对于每一个空位置,考虑上下左右各有多少棵树,然后就是这四个方向上树的数量中选\(K\)棵出来 ...

  2. 【BZOJ1227】[SDOI2009]虔诚的墓主人

    E. 虔诚的墓主人 题目描述 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地.当地的居民都是非常虔诚的基督徒,他们愿意提前 ...

  3. 【bzoj1227】 SDOI2009—虔诚的墓主人

    http://www.lydsy.com/JudgeOnline/problem.php?id=1227 (题目链接) 题意 一个n*m的公墓,一个点上要么是墓地,要么是常青树,给出一个数K,并规定每 ...

  4. P2154 [SDOI2009]虔诚的墓主人 树状数组

    https://www.luogu.org/problemnew/show/P2154 题意 在一个坐标系中,有w(1e5)个点,这个图中空点的权值是正上,正下,正左,正右各取k个的排列组合情况.计算 ...

  5. [洛谷P2154] SDOI2009 虔诚的墓主人

    问题描述 小W是一片新造公墓的管理人.公墓可以看成一块N×M的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. 当地的居民都是非常虔诚的基督徒,他们愿意提前为自己找一块合适墓地. ...

  6. P2154 [SDOI2009]虔诚的墓主人

    略有一点点思维的题. 首先,如果一个点上,下,左,右分别有\(a,b,c,d\)棵树,那这个点的十字架方案为\(C_{a}^{k}C_{b}^{k}C_{c}^{k}C_{d}^{k}\). 按x坐标 ...

  7. luogu P2154 [SDOI2009]虔诚的墓主人

    luogu 下面记一个点上下左右点数分别为\(u_i,d_i,l_i,r_i\) 枚举每个中间点太慢了,考虑枚举两个点之间横的一条线段,这里面的点左边点数目都相同,右边点数目都相同,然后只要查一下区间 ...

  8. BZOJ1227 SDOI2009 虔诚的墓主人【树状数组+组合数】【好题】*

    BZOJ1227 SDOI2009 虔诚的墓主人 Description 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. ...

  9. bzoj1227 [SDOI2009]虔诚的墓主人(组合公式+离散化+线段树)

    1227: [SDOI2009]虔诚的墓主人 Time Limit: 5 Sec  Memory Limit: 259 MBSubmit: 803  Solved: 372[Submit][Statu ...

随机推荐

  1. 2019.04.09 电商24 订单模快 ORM

    前面三个模块已近结束,现在看是订单模块的.想一下淘宝上的订单,在购物车中选中,提交,跳转到订单界面. 获取传过来的信息,那也要建立一个订单表,当我支付的时候,也要获取一些数据,将这些数据放到这个表中 ...

  2. Permission denied: user=root, access=WRITE, inode="/":hadoopuser:supergroup:drwxr-xr-x

    提示往HDFS写文件是不容许的. 在conf/hdfs-site.xml中加入: <property> <name>dfs.permissions</name> & ...

  3. sqli-labs(十)(过滤注释符)

    第二十三关: 这关还是一个GET型.字符串.单引符号.的有报错的sql注入,输入?id=1'  ,页面会报错 我们继续按照之前的套路来,先输入?id=1' or '1'='1 页面正常显示,说明这个地 ...

  4. Lepus(天兔)监控MySQL部署

    http://www.dbarun.com/docs/lepus/install/lnmp/ 注意:xampp mysqldb-python版本太高会导致lepus白屏 apache版本最好选择2.2 ...

  5. System.BadImageFormatException”C#报错

    在平常的开发中或多或少会遇到一些问题,而本次向小编这里是自己刚刚解决的一个问题,贴出来与大家分享一下,纠结了一个下午,终于解决了,是有关平台的一个报错问题.   方法/步骤     报错”“Syste ...

  6. sqoop往远程hdfs写入数据时出现Permission denied 的问题

    猜测出现该问题的原因是sqoop工具用的是执行sqoop工具所用的本地用户名. 如果远程hdfs用的用户是hdfs,那么我本地还需要建一个名为hdfs的用户? 其实不需要,只要为用户增加一个环境变量就 ...

  7. 解决sqlserver修改被阻止的提示

    https://jingyan.baidu.com/article/f79b7cb3664f299144023ef8.html 工具——选项——选择designers---表设计器和数据库设计器,将阻 ...

  8. .NET Core Tools for Visual Studio 2015 安装失败

    You may be blocked from installing the .NET Core Tooling Preview 2 for Visual Studio 2015 installer ...

  9. 擠出線寬(Extrusion width),要怎麼設定?

    擠出線寬(Extrusion width),要怎麼設定? Slic3r的作者,把這邊的%設定,跟"層高"做連結.我個人認為擠出線寬,要以噴頭孔徑當做設定參考才好.層高應該只要設定成 ...

  10. Latex数学公式中的空格

    http://blog.sina.com.cn/s/blog_4ddef8f80100iwwv.html 两个quad空格 a \qquad b 两个m的宽度 quad空格 a \quad b 一个m ...