如果只有行和列的覆盖,那么可以直接做,但现在有左上到右下的覆盖.

考虑对行和列的覆盖情况做一个卷积,然后就有了x+y的非覆盖格子数.

然后用骑士的左上到右下的覆盖特判掉那些x+y的格子就可以了.

注意题意,Row是从上到下来的,被坑得好惨.

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<ctime>
  7. #include<string>
  8. #include<iomanip>
  9. #include<algorithm>
  10. #include<map>
  11. using namespace std;
  12. #define LL long long
  13. #define FILE "dealing"
  14. #define up(i,j,n) for(LL i=j;i<=n;++i)
  15. #define db double
  16. #define ull unsigned long long
  17. #define eps 1e-10
  18. #define pii pair<LL,LL>
  19. LL read(){
  20. LL x=0,f=1,ch=getchar();
  21. while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
  22. while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
  23. return f*x;
  24. }
  25. const LL maxn=402000,maxm=20000,mod=(LL)(1e9+7+0.1),limit=(LL)(1e6+1),inf=(LL)(1e9);
  26. bool cmax(LL& a,LL b){return a<b?a=b,true:false;}
  27. bool cmin(LL& a,LL b){return a>b?a=b,true:false;}
  28. namespace FFT{
  29. db pi=acos(-1.0);
  30. struct cp{
  31. db x,y;
  32. cp(db x=0,db y=0):x(x),y(y){}
  33. cp operator+(const cp& b){return cp(x+b.x,y+b.y);}
  34. cp operator-(const cp& b){return cp(x-b.x,y-b.y);}
  35. cp operator*(const cp& b){return cp(x*b.x-y*b.y,x*b.y+y*b.x);}
  36. }w[maxn],a[maxn],b[maxn];
  37. LL R[maxn],H,L;
  38. void FFT(cp* a,LL f){
  39. up(i,0,L-1)if(i<R[i])swap(a[i],a[R[i]]);
  40. for(LL len=2;len<=L;len<<=1){
  41. LL l=len>>1;
  42. cp wn(cos(pi/l),f*sin(pi/l));
  43. up(i,1,l-1)w[i]=w[i-1]*wn;
  44. for(LL st=0;st<L;st+=len)
  45. for(LL k=0;k<l;k++){
  46. cp x=a[st+k],y=w[k]*a[st+k+l];
  47. a[st+k]=x+y;a[st+k+l]=x-y;
  48. }
  49. }
  50. if(f==-1)up(i,0,L-1)a[i].x/=L;
  51. }
  52. void solve(LL* c,LL* d,LL n,LL m,LL* ch){
  53. n++,m++;
  54. up(i,0,n-1)a[i].x=c[i],a[i].y=0;
  55. up(i,0,m-1)b[i].x=d[i],b[i].y=0;
  56. for(H=0,L=1;L<n+m-1;H++)L<<=1;
  57. up(i,n,L)a[i].x=a[i].y=0;
  58. up(i,m,L)b[i].x=b[i].y=0;
  59. up(i,1,L)R[i]=(R[i>>1]>>1)|((i&1)<<(H-1));
  60. w[0].x=1;
  61. FFT(a,1);FFT(b,1);
  62. up(i,0,L-1)a[i]=a[i]*b[i];
  63. FFT(a,-1);
  64. up(i,1,n+m-1)ch[i]=(LL)(a[i].x+0.5);
  65. }
  66. };
  67. LL n,m,K;
  68. LL a[maxn],b[maxn],c[maxn],d[maxn];
  69. int main(){
  70. freopen(FILE".in","r",stdin);
  71. freopen(FILE".out","w",stdout);
  72. LL T=read();
  73. up(j,1,T){
  74. n=read(),m=read(),K=read();
  75. up(i,1,n)a[i]=1;
  76. up(i,1,m)b[i]=1;
  77. up(i,1,n+m)d[i]=0;
  78. up(i,1,K){
  79. LL x=n-read()+1,y=read();
  80. a[x]=0,b[y]=0;
  81. d[x+y]=1;
  82. }
  83. FFT::solve(a,b,n,m,c);
  84. LL ans=0;
  85. up(i,1,n+m)if(c[i]&&!d[i])ans+=c[i];
  86. printf("Case %lld: %lld\n",j,ans);
  87. }
  88. return 0;
  89. }

  

[UVA 12633] Super Rooks on Chessboard FFT+计数的更多相关文章

  1. UVA 12633 Super Rooks on Chessboard [fft 生成函数]

    Super Rooks on Chessboard UVA - 12633 题意: 超级车可以攻击行.列.主对角线3 个方向. R * C 的棋盘上有N 个超级车,问不被攻击的格子总数. 行列好好做啊 ...

  2. UVA 12633 Super Rooks on Chessboard(FFT)

    题意: 给你一个R*C的棋盘,棋盘上的棋子会攻击,一个棋子会覆盖它所在的行,它所在的列,和它所在的从左上到右下的对角线,那么问这个棋盘上没有被覆盖的棋盘格子数.数据范围R,C,N<=50000 ...

  3. UVA 12633 Super Rooks on Chessboard ——FFT

    发现对角线上的和是一个定值. 然后就不考虑斜着,可以处理出那些行和列是可以放置的. 然后FFT,统计出每一个可行的项的系数和就可以了. #include <map> #include &l ...

  4. UVA 12633 Super Rooks on Chessboard (生成函数+FFT)

    题面传送门 题目大意:给你一张网格,上面有很多骑士,每个骑士能横着竖着斜着攻击一条直线上的格子,求没被攻击的格子的数量总和 好神奇的卷积 假设骑士不能斜着攻击 那么答案就是没被攻击的 行数*列数 接下 ...

  5. UVa12633 Super Rooks on Chessboard(容斥 + FFT)

    题目 Source http://acm.hust.edu.cn/vjudge/problem/42145 Description Let’s assume there is a new chess ...

  6. UVA12633 Super Rooks on Chessboard

    题目描述 题解: 第一眼满眼骚操作,然后全部否掉. 然后屈服于题解,才发现这题这么执掌. 首先,如果这个东西是普通的车,那我们可以记录一下$x,y$的覆盖情况,然后减一下; 但是这个可以斜着走. 所以 ...

  7. UVA - 12298 Super Poker II NTT

    UVA - 12298 Super Poker II NTT 链接 Vjudge 思路 暴力开个桶,然后统计,不过会T,用ntt或者fft,ntt用个大模数就行了,百度搜索"NTT大模数&q ...

  8. UVA - 11134 Fabled Rooks[贪心 问题分解]

    UVA - 11134 Fabled Rooks We would like to place n rooks, 1 ≤ n ≤ 5000, on a n × n board subject to t ...

  9. uva 11134 - Fabled Rooks(问题转换+优先队列)

    题目链接:uva 11134 - Fabled Rooks 题目大意:给出n,表示要在n*n的矩阵上放置n个车,并且保证第i辆车在第i个区间上,每个区间给出左上角和右小角的坐标.另要求任意两个车之间不 ...

随机推荐

  1. 压缩软件Snappy的安装

    1.下载源码,通过编译源码安装  tar -zxvf  /home/zfll/soft/snappy-1.1.2.tar.gz cd snappy-1.1.2 ./configure make sud ...

  2. 【AngularJS】Yeoman安装

    看不到PPT的请自行解决DNS污染问题.

  3. IP、操作系统、移动OS

    IP IP地址 = 网络地址 + 主机地址/IP地址 = 网络地址 + 子网地址 + 主机地址. DNS :进行域名解析的服务器.             比如,sina.com(是域名).其实是一个 ...

  4. 转:static关键字的总结

    static关键字的总结 C++的static有两种用法:面向过程程序设计中的static和面向对象程序设计中的static.前者应用于普通变量和函数,不涉及类:后者主要说明static在类中的作用. ...

  5. linux查看某个时间段的log

    若想在linux下查询某个时间段的log,用sed命令示例如下: $ sed -n '/2017-01-04 11:00:00/,/2017-01-04 11:20:55/p'  ejabberd.l ...

  6. maven新建项目报错

    创建了一个maven项目,报错 Errors occurred during the build. Errors running builder 'Maven Project Builder' on ...

  7. 【转】一步一步带你反编译apk,并教你修改smali和重新打包

    一.工具介绍: 1.apktool:aapt.exe,apktool.bat,apktool.jar;三个在同一目录结合使用,用来反编译apk,apk重新打包: 2.dex2jar:该工具作用是将cl ...

  8. linux 设置静态IP方法

    本系统使用 linux redhat 7.2 1.   修改ip vi   /etc/sysconfig/network-scripts/ifcfg-eno16777736 2. 修改数据项如下 3. ...

  9. 如何理解API,API 是如何工作的

    大神博客:https://blog.csdn.net/cumtdeyurenjie/article/details/80211896

  10. 【BZOJ4435】[Cerc2015]Juice Junctions Tarjan+hash

    [BZOJ4435][Cerc2015]Juice Junctions Description 你被雇佣升级一个旧果汁加工厂的橙汁运输系统.系统有管道和节点构成.每条管道都是双向的,且每条管道的流量都 ...