╰( ̄▽ ̄)╭

济南市“泉历史研究小组”依据济南特有的泉脉关系将济南的泉水分为六个区域,分别是市中区、历下区、天桥区、槐荫区、历城区、长清区。

作为光荣的济南泉历史研究小组中的一员,铭铭收集了历史上N 个不同年份时不同泉区的泉水流量指数,这个指数是一个小于2^30 的非负整数。第i 个年份时六个泉区的泉水流量指数分别为A(i,1),A(i,2),A(i,3),A(i,4),A(i,5)与A(i,6)。

现在铭铭希望知道有多少对不同的年份:i 和j,满足这两年恰好有K 个泉区的泉水流量指数对应相同。

  1. 对于100%的数据,N<=100000A<=2^30
  2. 0<=K<=6,且所有数据中K 是等概率出现的,即对于任意的0<=x<=6,都有大约1/7 的数据中K=x

(⊙ ▽ ⊙)

首先计算出f[i],其中i∈[0,26):

例如f[0110012]表示,满足第2、3、6位相同的年份有多少对。

这个可以通过Hash,O(6∗n)求出。


考虑容斥原理

设g[k]表示,当题目所给的K=k时的答案。

对于所有的f[i],设num为i中1的个数(选了多少位相同)。

g[k]+=f[i]∗Cknum∗(−1)num−k (k∈[0,num])


答案即为g[K]。

( ̄~ ̄)

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<stdio.h>
  4. #include<math.h>
  5. #include<string.h>
  6. #define ll long long
  7. using namespace std;
  8. const char* fin="ex3295.in";
  9. const char* fout="ex3295.out";
  10. const ll inf=0x7fffffff;
  11. const ll maxn=100007,maxh=9999997,maxH=7394895,hh=137,HH=37;
  12. ll n,m,i,j,k;
  13. ll a[maxn][6],bz[6],c[10][10],f[7];
  14. ll id;
  15. struct node{
  16. ll y,z,cnt;
  17. bool ok(){
  18. return z==id;
  19. }
  20. }h[maxh];
  21. ll hash(ll v,ll v1){
  22. ll k=v%maxh,l=0;
  23. while (h[k].ok() && h[k].y!=v1){
  24. k=(k+1)%maxh;
  25. }
  26. return k;
  27. }
  28. void dfs(ll l,ll num){
  29. ll i,j,k;
  30. if (l==6){
  31. ll ans=0;
  32. id++;
  33. for (i=1;i<=n;i++){
  34. ll tmp=0,tmd=0;
  35. for (j=0;j<6;j++)
  36. if (bz[j]){
  37. tmp=(tmp*hh+(a[i][j]%maxh))%maxh;
  38. tmd=(tmd*HH+(a[i][j]%maxH))%maxH;
  39. }
  40. k=hash(tmp,tmd);
  41. if (h[k].z<id){
  42. h[k].cnt=0;
  43. h[k].z=id;
  44. }
  45. h[k].y=tmd;
  46. ans+=h[k].cnt;
  47. h[k].cnt++;
  48. }
  49. for (i=num;i>=0;i--) f[i]+=c[num][i]*ans*((num-i)%2?-1:1);
  50. return;
  51. }
  52. bz[l]=1;
  53. dfs(l+1,num+1);
  54. bz[l]=0;
  55. dfs(l+1,num);
  56. }
  57. int main(){
  58. scanf("%lld%lld",&n,&m);
  59. for (i=0;i<10;i++){
  60. c[i][0]=1;
  61. for (j=1;j<=i;j++) c[i][j]=c[i-1][j]+c[i-1][j-1];
  62. }
  63. for (i=1;i<=n;i++) for (j=0;j<6;j++) scanf("%lld",&a[i][j]);
  64. dfs(0,0);
  65. printf("%lld",f[m]);
  66. return 0;
  67. }

(⊙v⊙)

1.hh要取质数,并且尽量浮夸一点。

2.看到恰好二字,就可以考虑容斥原理

【JZOJ3295】【SDOI2013】泉(spring)的更多相关文章

  1. [SDOI2013]泉

    题目描述 作为光荣的济南泉历史研究小组中的一员,铭铭收集了历史上x个不同年份时不同泉区的水流指数,这个指数是一个小于. 2^30的非负整数.第i个年份时六个泉区的泉水流量指数分别为 A(i,l),A( ...

  2. [SDOI2013]泉(容斥)

    /* 容斥加上哈希 首先我们可以2 ^ 6枚举相同情况, 然后对于这些确定的位置哈希一下统计方案数 这样我们就统计出了这些不同方案的情况, 然后容斥一下就好了 */ #include<cstdi ...

  3. 【[SDOI2013]泉】

    \(hash\)+容斥 但是看到这个令人愉快的数据范围还是直接枚举子集吧 首先我们发现\(6\)这个东西简直是小的可怜,复杂度里肯定有\(2^6\)的 于是我们可以直接先枚举子集,把所有状态的对应相等 ...

  4. 题解 洛谷 P3298 【[SDOI2013]泉】

    考虑到年份数很小,只有 \(6\),所以可以 \(2^6\) 来枚举子集,确定流量指数对应相同的位置,然后通过哈希和排序来计算相同的方案数. 但是这样计算出的是大于等于子集元素个数的方案数,所以还需要 ...

  5. Noip前的大抱佛脚----赛前任务

    赛前任务 tags:任务清单 前言 现在xzy太弱了,而且他最近越来越弱了,天天被爆踩,天天被爆踩 题单不会在作业部落发布,所以可(yi)能(ding)会不及时更新 省选前的练习莫名其妙地成为了Noi ...

  6. NOIP前的刷题记录

    因为这几天要加油,懒得每篇都来写题解了,就这里记录一下加上一句话题解好了 P4071 [SDOI2016]排列计数   组合数+错排 loj 6217 扑克牌 暴力背包 P2511 [HAOI2008 ...

  7. CET4词汇

    abandon vt.丢弃:放弃,抛弃 ability n.能力:能耐,本领 abnormal a.不正常的:变态的 aboard ad.在船(车)上:上船 abroad ad.(在)国外:到处 ab ...

  8. BZOJ 3198: [Sdoi2013]spring [容斥原理 哈希表]

    3198: [Sdoi2013]spring 题意:n个物品6个属性,求有多少不同的年份i,j满足有k个属性对应相等 一开始读错题了,注意是对应相等 第i个属性只能和第i个属性对应 容斥一下 \[ 恰 ...

  9. bzoj3198[Sdoi2013]spring 容斥+hash

    3198: [Sdoi2013]spring Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 1143  Solved: 366[Submit][Sta ...

随机推荐

  1. java RSA验签

    这几天在跟一个php的小哥哥联调接口,遇到了一些问题记录下来, 直接上代码吧,亲测有效 import org.slf4j.Logger; import org.slf4j.LoggerFactory; ...

  2. <每日一题>题目9:求质数V1.0

    num= input("请输入您要求质数的范围(以逗号结尾):") down,up = num.split(',',1) down,up = int(down),int(up) i ...

  3. C#生成指定范围内的不重复随机数

    C#生成指定范围内的不重复随机数 // Number随机数个数 // minNum随机数下限 // maxNum随机数上限 public int[] GetRandomArray(int Number ...

  4. MVVM基础概念和理解

    在MVVM模式中,View封装UI和UI逻辑,viewmodel封装presentation逻辑,model封装业务逻辑和数据. View类 View的责任是定义屏幕上的结构和外观,在完美的情况下,v ...

  5. activiti 连线

    实际使用中工作流往往不是一条直线进行下去,例如请假的话可以部门经理直接同意,或者报总经理同意,流程图示意如下. 可以看到,面对一个事情,重要的才要总经理审批否则仅部门经理审批即可.因此在完成任务的时候 ...

  6. springboot2配置druid数据库连接池

    注意配置以下的依赖: <!-- 引入druid数据源--> <dependency> <groupId>com.alibaba</groupId> &l ...

  7. MapReduce深入理解输入和输出格式(2)-输入和输出完全总结

    MapReduce太高深,性能也值得考虑,大家感兴趣的还是看看spark比较好. FileInputFormat类 FileInputFormat是所有使用文件为数据源的InputFormat实现的基 ...

  8. mysql系统变量与状态变量

    一.系统变量分为全局系统变量和会话系统变量:有些变量既是全局系统变量,有些变量只有全局的,有些变量只有会话的. .变量的查询: show global variables like 'log' \G; ...

  9. Autoware显示用户界面细节

    https://blog.csdn.net/jianxuezixuan/article/details/86015224

  10. LUOGU P2280 [HNOI2003]激光炸弹

    传送门 解题思路 二维前缀和. 代码 #include<iostream> #include<cstdio> #include<cstring> using nam ...