bzoj1879: [Sdoi2009]Bill的挑战(codevs2308)(luoguP2167) 状压dp
唔...懒兔子来写博客了...
这题的话...我想了很久但是都不是可行解
刚开始想预处理任意两个串是否可以匹配然后在乱搞,后来发现完全不会写...
然后按照惯例,我会看题解认真的思考...
唔...其实看完题解貌似这题还挺容易的?
我们可以预处理一个数组 g[i,j] 表示 在这 n 个串中前 i 个字符且第 i 个字符匹配为 j (j 是一个字符) 时的一个状态。
这个状态为一个长度为n的 2进制数转为10进制。比如 111 这个状态指 1 串和2 串和 3 串都是可以匹配的。
这个数组就是这个作用。
辣它可以干什么捏。
我萌进入dp部分。
设 f[i,j] 表示 每个串前 i 个字符 状态为 j 的方案数。
初始化就是 f[0,1 << n-1]=1
答案就是 sum(f[n,j]) 这里的 j 状态要满足 二进制1 的个数为 k。
j 这个状态指 n 个串中选了哪些串。
f[i,j & g[i,x]+=f[i-1,j]
枚举一个 x 字符,对于 ‘a’-‘z’ 这些字符都可以是第 i 位的。
然后枚举前继状态 j 辣么 对于要更新的状态就是 j & g[i,x]
为什么是&? 因为如果能转移到的必须要满足 g[i,x] 中能匹配这个串 同时前继状态也要有。
而 & 就是只有两个都是1 的时候才为 1 ,所以 & 后就是可以转移的一个状态。
这样打完之后捏,我兴高采烈的交了上去。TLE!!!
算了一下效率,似乎是卡着的呀QAQ
怀疑兔生的我优化了常数,以为是常数的锅。
结果还是 TLE! TLE!TLE!
然后怀疑兔生的又看了一次题解 开始思考原因
发现题解里加了优化的QAQ 但是并没有说...
所以要加一个优化咯。
这样考虑对于 f[i-1,j]=0 的情况 实际上可以不去转移,这样可以省掉很多时间。
const HR=;
var s:string;
i,j,x:longint;
g:array[..,..]of longint;
t,n,k:longint;
f:array[..,..]of longint;
num:array[..]of longint;
len:longint;
ans:longint;
function check(x:longint):longint;
var i,num:longint;
begin
num:=;
for i:= to do
if ( << (i-))and x> then inc(num);
exit(num);
end;
begin
read(t);
for i:= to ( << )- do
num[i]:=check(i);
while t> do
begin
dec(t);
ans:=;
readln(n,k);
for i:= to n do
begin
readln(s);
if i= then len:=length(s);
for j:= to len do
for x:= to do
if ((ord(s[j])-)=x)or(s[j]='?') then
g[j,x]:=g[j,x] or ( << (i-));
end;
f[,( << n)-]:=;
for i:= to len do
begin
for j:= to ( << n)- do
if f[i-,j]<> then
begin
for x:= to do
begin
inc(f[i,(g[i,x] and j)],f[i-,j]);
if f[i,(g[i,x] and j)]>=HR then
f[i,(g[i,x] and j)]:=f[i,(g[i,x] and j)] mod HR;
end;
f[i-,j]:=;
end;
if i=len then
begin
for j:= to ( << n)- do
begin
if num[j]=k then
begin
inc(ans,f[len,j]);
if ans>=HR then ans:=ans mod HR;
end;
f[i,j]:=;
end;
end;
end;
for i:= to len do
for x:= to do
g[i,x]:=;
writeln(ans);
end;
end.
bzoj1879
代码巨丑...懒兔子懒得弄好看点了QAQ
bzoj1879: [Sdoi2009]Bill的挑战(codevs2308)(luoguP2167) 状压dp的更多相关文章
- [LuoguP2167][SDOI2009]Bill的挑战_容斥原理/状压dp
Bill的挑战 题目链接:https://www.luogu.org/problem/P2167 数据范围:略. 题解: 因为$k$特别小,想到状压. 状压的方式也非常简单,就是暴力枚举. 但是会不会 ...
- [bzoj1879][Sdoi2009]Bill的挑战_动态规划_状压dp
Bill的挑战 bzoj-1879 Sdoi-2009 题目大意: 注释:$1\le t \le 5$,$1\le m \le 15$,$1\le length \le 50$. 想法: 又是一个看数 ...
- BZOJ1879:[SDOI2009]Bill的挑战(状压DP)
Description Input 本题包含多组数据. 第一行:一个整数T,表示数据的个数. 对于每组数据: 第一行:两个整数,N和K(含义如题目表述). 接下来N行:每行一个字符串. T ≤ ...
- bzoj千题计划207:bzoj1879: [Sdoi2009]Bill的挑战
http://www.lydsy.com/JudgeOnline/problem.php?id=1879 f[i][j] 表示匹配了i个字符,匹配字符串的状态为j的方案数 枚举下一个字符是什么 计算加 ...
- Bzoj1879 [Sdoi2009]Bill的挑战
Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 724 Solved: 363 Description Input 本题包含多组数据. 第一行:一个整数T ...
- BZOJ1879 [Sdoi2009]Bill的挑战 【状压dp】
题目 输入格式 本题包含多组数据. 第一行:一个整数T,表示数据的个数. 对于每组数据: 第一行:两个整数,N和K(含义如题目表述). 接下来N行:每行一个字符串. T ≤ 5,M ≤ 15,字符串长 ...
- 【BZOJ1879】[Sdoi2009]Bill的挑战 状压DP
[BZOJ1879][Sdoi2009]Bill的挑战 Description Input 本题包含多组数据. 第一行:一个整数T,表示数据的个数. 对于每组数据: 第一行:两个整数,N和K(含 ...
- 【BZOJ1879】【SDOI2009】Bill的挑战 [状压DP]
Bill的挑战 Time Limit: 4 Sec Memory Limit: 64 MB[Submit][Status][Discuss] Description Input 第一行:一个整数T, ...
- 【BZOJ1879】[SDOI2009]Bill的挑战(动态规划)
[BZOJ1879][SDOI2009]Bill的挑战(动态规划) 题面 BZOJ 洛谷 题解 本来还想着容斥来着,这个数据范围直接暴力就好.设\(f[i][S]\)表示当前填到了第\(i\)位,和\ ...
随机推荐
- mysql IPv4 IPv6
w如何通过一个mysql方法,而不是借助脚本判断?INET6_ATON(expr) https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-func ...
- Python 之 UUID
UUID是根据MAC以及当前时间等创建的不重复的随机字符串 import uuid # Generate a UUID from a host ID, sequence number, and the ...
- python-gitlab 模块
安装:pip install python-gitlab import gitlab # 登录 gl = gitlab.Gitlab('http://127.0.0.1', private_token ...
- mysql总结思维导图
mysql总结思维导图.脑图 先整理了一个思维导图出来,到时候再继续补充并且深入挖掘一下,再写博文. 另外,看了很多优秀的博文,在这里先mark一下. https://www.cnblogs.com/ ...
- 一个父亲的教育札记——leo鉴书58
由于年纪和工作的原因.绝大部分小说我都不看--没空,如今小说写的也太空.但对文笔有提高的文章我是非常关注的,知道韩寒不是由于<三重门>(我报纸也不怎么看).而是此前编辑感觉我文笔差. ...
- send/receive h264/aac file/data by rtp/rtsp over udp/tcp
一.安装一些必要的调试工具 1.vlc安装sudo apt-get install vlcsudo apt-get install vlc-nox 2.ffmpeg安装,带ffplay,ffplay依 ...
- 使用DAO工厂创建实现类对象
首先分析DAO模式中的每一部分 VO(对象实体):这个类成员变量与数据库中每个字段一一对应,同时提供了相应是set和get方法来设置或取得数值.这个类一般是通过IDE自动生成的 DAO(数据访问接口) ...
- [Python] logging.logger
<1>. mylogger = logging.getLogger("abc") logging.debug()/logging.info()/logging.warn ...
- python 中元祖tuple的使用
Python的元组与列表类似,不同之处在于元组的元素不能修改. 元组使用小括号,列表使用方括号. 元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可. eg, tup1 = (1, 2, 3 ...
- 支持向量机SVM、优化问题、核函数
1.介绍 它是一种二类分类模型,其基本模型定义为特征空间上的间隔最大的线性分类器,即支持向量机的学习策略便是间隔最大化,最终可转化为一个凸二次规划问题的求解. 2.求解过程 1.数据分类—SVM引入 ...