题目描述

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

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

输入输出格式

输入格式:

第一行有2个整数,分别是N和K

之后N行,每行有6个整数。第i行的第j个数字A(i,j)表示第i个年份屮第j个泉区的泉水流量指数。

输出格式:

一个整数表示有多少对不同的年份满足恰有K个区的泉水流量指数对应相同。

输入输出样例

输入样例#1: 复制

3 3

1 2 3 4 5 6

1 2 3 0 0 0

0 0 0 4 5 6

输出样例#1: 复制

2

说明

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


题解

这题卡哈希好蛋疼

观察题目发现k很小,所以可以枚举所有情况

用哈希表存储每种哈希值出现的次数

然后因为是恰好k个泉区

所以我们要容斥掉所有的>k个泉区的方案数

答案就是至少k个泉区的方案数 - 至少是k+1个泉区的方案数 * \(C(k + 1 , k)\) + 至少是k+2个泉区的方案数 * \(C(k+2,k)\)

为什么要去乘组合数呢?

因为每个至少是\(k+a(a>0)\)个泉区相同的方案对至少是k个泉区相同的方案数的贡献是\(C(k+a,k)\)

而我们要求的是恰好,所以要将他们减去

代码

#include<cstdio>
#include<cstring>
#include<cstring>
#include<iostream>
#include<algorithm>
# define LL long long
# define ull unsigned long long
const ull Base = 233333 ;
const ull mod = 999983 ;
const int M = 100005 ;
using namespace std ;
inline int read() {
char c = getchar() ; int x = 0 , w = 1 ;
while(c>'9'||c<'0') { if(c=='-') w = -1 ; c = getchar() ; }
while(c>='0'&&c<='9') { x = x*10+c-'0' ; c = getchar() ; }
return x*w ;
} int n , m ;
int val[M][8] ;
int c[8][8] ;
LL Ans ;
int hea[M * 10] , num ;
struct E {
int Nxt , cnt ; ull to ;
} edge[M * 10] ;
inline int chk(int x) {
int ret = 0 ;
for(int i = 1 ; i <= 6 ; i ++)
if(x & (1 << (i - 1)))
++ret ;
return ret ;
}
inline void insert(ull x) {
int u = x % mod ;
for(int i = hea[u] ; i ; i = edge[i].Nxt) {
ull v = edge[i].to ;
if(v == x) { edge[i].cnt ++ ; return ; }
}
edge[++num].Nxt = hea[u] ; edge[num].to = x ; edge[num].cnt = 1 ; hea[u] = num ;
}
inline void Solve(int x) {
int ret = 0 ;
LL temp = 0 ;
for(int i = 1 ; i <= n ; i ++) {
ull h = 0 ;
for(int j = 1 ; j <= 6 ; j ++)
if(x & (1 << (j - 1)))
h = h * Base + val[i][j] ;
insert(h) ;
}
for(int i = 1 ; i <= 6 ; i ++) if(x & (1 << (i - 1))) ++ret ;
for(int i = 1 ; i <= num ; i ++) temp += 1LL * ((edge[i].cnt - 1) * edge[i].cnt) / 2 ;
temp *= c[ret][m] ;
memset(hea , 0 , sizeof(hea)) ; num = 0 ;
if((ret - m) % 2) Ans -= temp ;
else Ans += temp ;
}
int main() {
n = read() ; m = read() ;
for(int i = 1 ; i <= n ; i ++)
for(int j = 1 ; j <= 6 ; j ++)
val[i][j] = read() ;
c[0][0] = 1 ;
for(int i = 1 ; i <= 6 ; i ++) {
c[i][0] = 1 ;
for(int j = 1 ; j <= i ; j ++)
c[i][j] = c[i - 1][j] + c[i - 1][j - 1] ;
}
for(int i = 0 ; i < (1 << 6) ; i ++)
if(chk(i) >= m)
Solve(i) ;
cout << Ans << endl ;
return 0 ;
}

[SDOI2013]泉的更多相关文章

  1. [SDOI2013]泉(容斥)

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

  2. 【[SDOI2013]泉】

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

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

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

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

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

  5. NOIP前的刷题记录

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

  6. 【JZOJ3295】【SDOI2013】泉(spring)

    ╰( ̄▽ ̄)╭ 济南市"泉历史研究小组"依据济南特有的泉脉关系将济南的泉水分为六个区域,分别是市中区.历下区.天桥区.槐荫区.历城区.长清区. 作为光荣的济南泉历史研究小组中的一员 ...

  7. BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]

    3130: [Sdoi2013]费用流 Time Limit: 10 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 960  Solved: 5 ...

  8. Centos 下安装 文泉驿 字体 Odoo

    刚装完centos下的odoo的字体 文泉驿 ,一万头草泥马呼啸而过.....劝君如非必要,千万别再centos下折腾odoo..... 正题,文泉驿官网 只提供 deb包和源码包的字体安装 ,想在c ...

  9. freebsd|odoo - 为odoo报表 安装文泉译中文字体

    来源: Odoo8.0中使用文泉译中文字体         http://blog.csdn.net/vnsoft/article/details/40056935 FreeBSD wkhtmltop ...

随机推荐

  1. [luoguP2444] [POI2000]病毒(AC自动机 + dfs)

    传送门 先把所有串建一个AC自动机, 如果要找一个不包含任意一个串的串, 说明这个串一直在AC自动机上匹配但匹配不到, 也就是说,匹配时除去val值为1的点,除去fail指针指向val值为1的点,是否 ...

  2. Codeforces704C. Black Widow

    n<=1e5个值v,分别由<=1e5的m个变量中的1<=ki<=2个布尔变量xj(或某个变量取反)或起来组成,而所有的v异或起来为1,一个x不会在输入数据中出现超过2次,包括他 ...

  3. CF901C. Bipartite Segments

    n<=300000,m<=300000的图,图上只有奇环,q<=300000个询问每次问:一个区间内有多少个子区间,满足只保留编号在该区间的点以及他们之间的边,可以构成一个二分图. ...

  4. JQuery判断radio是否选中并获取选中值的示例代码

    这篇文章主要介绍了JQuery判断radio是否选中并获取选中值的方法,代码很简单,但很实用,需要的朋友可以参考下 其他对radio操作功能,以后在添加.直接上代码,别忘记引用JQuery包 ? 1 ...

  5. P1219 八皇后 洛谷

    题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...

  6. SecureCRT在Tab下的Title显示IP

    注意:要针对每个Session进行修改才行. 参考: http://www.cnblogs.com/tyhmj/archive/2013/12/20/3483247.html

  7. JSP国际化设置

    以下内容引用自http://wiki.jikexueyuan.com/project/jsp/internationalization.html: 国际化(i18n):这意味着可以使网站根据访问者的语 ...

  8. Android之AssetManager使用

    1. 获取AssetManager AssetManager assetManager = context.getAssets(); 2. 列出assets文件夹下全部文件 String[] file ...

  9. netty4与protocol buffer结合简易教程

    各项目之间通常使用二进制进行通讯,占用带宽小.处理速度快~ 感谢netty作者Trustin Lee.让netty天生支持protocol buffer. 本实例使用netty4+protobuf-2 ...

  10. jmeter实现Http接口测试介绍

    构建一个测试页面 页面功能测试说到底就是模拟用户浏览点击页面的全过程,很多的测试工具都可以对该过程进行录制后模拟用户操作,而压力测试就是将这个过程在单位时间内重复成千上万次,看检测应用的高可用,接下来 ...