[bzoj1195][HNOI2006]最短母串_动态规划_状压dp
最短母串 bzoj-1195 HNOI-2006
题目大意:给一个包含n个字符串的字符集,求一个字典序最小的字符串使得字符集中所有的串都是该串的子串。
注释:$1\le n\le 12$,$1\le max length \le 50$。
想法:刚开始在那里AC自动机半天,然后瞅了一眼数据范围... ...状压吧兄弟!!
首先,我们先做一些预处理:把可以被字符集中串包含的串都删掉;求出两个字符串连接后的长度(这个预处理暴力即可),设merge[i][j]表示串i和串j合并后的长度。
状态:dp[s][i]表示这个串已经包含了s状态的字符串且紧跟着的串是i的最短长度。
转移:dp[s][i]=min{dp[s^(1<<(j+1))][j]+merge[i][j]-length(j)};
最后,附上丑陋的代码... ...
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
using namespace std;
const int INF=0x3f3f3f3f;
const int mxn=61;
int n;
struct bind
{
char s[605];
int len;
bool operator < (const bind y) const
{
if(len!=y.len)return len<y.len;
for(int i=0;i<len;i++)
if(s[i]!=y.s[i])return s[i]<y.s[i];
return 0;
}
}f[1<<12][12],s[12];
int c[13][13];
bool ban[mxn]; bool ovl(int i,int j)
{
if(s[i].len<s[j].len)return 0;
char *p=strstr(s[i].s,s[j].s);
if(p==NULL)return 0;
return 1;
}
int clc(int x,int y)
{
bool flag=0;
for(int i=max(0,s[x].len-s[y].len);i<s[x].len;i++)
{
flag=1;
for(int j=i;j<s[x].len;j++)
if(s[x].s[j]!=s[y].s[j-i]){flag=0;break;}
if(flag)return s[x].len-i;
}
return 0;
}
bind merge(int S,int u,int v)
{
bind tmp=f[S][u];
strcat(tmp.s,s[v].s+c[u][v]);
tmp.len=f[S][u].len-c[u][v]+s[v].len;
return tmp;
}
void Dp()
{
int i,j,ed=(1<<n)-1;
for(i=0;i<=ed;i++)
for(j=0;j<n;j++)f[i][j].len=INF;
for(i=0;i<n;i++)f[1<<i][i]=s[i];
for(i=1;i<=ed;i++)
{
for(j=0;j<n;j++)
{
if((i>>j)&1)
for(int k=0;k<n;k++)
{
if((i>>k)&1) continue;
bind tmp=merge(i,j,k);
if(tmp<f[i|(1<<k)][k])f[i|(1<<k)][k]=tmp;
}
}
}
}
int main()
{
scanf("%d",&n);
for(int i=0;i<n;i++)scanf("%s",s[i].s),s[i].len=strlen(s[i].s);
for(int i=0;i<n;i++)
for(j=0;j<n;j++)
if(i!=j && ovl(i,j) && !ban[i])ban[j]=1;
int cnt=0;
for(int i=0;i<n;i++)if(!ban[i])s[cnt++]=s[i];
n=cnt;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
if(i!=j)c[i][j]=clc(i,j);
Dp();
int ans=0,ed=(1<<n)-1;
for(int i=1;i<n;i++)
if(f[ed][i]<f[ed][ans])ans=i;
printf("%s",f[ed][ans].s);
return 0;
}
小结:看到了数据做题是一种解题想法,但是考试的时候看数据范围猜复杂度我tm就没成功过... ...
[bzoj1195][HNOI2006]最短母串_动态规划_状压dp的更多相关文章
- [HNOI2006]最短母串问题——AC自动机+状压+bfs环形处理
Description 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串. 32MB Input 第一行是一个正整数n(n< ...
- BZOJ1195[HNOI2006]最短母串——AC自动机+BFS+状态压缩
题目描述 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串. 输入 第一行是一个正整数n(n<=12),表示给定的字符串的 ...
- Bzoj1195 [HNOI2006]最短母串 [状态压缩]
Time Limit: 10 Sec Memory Limit: 32 MBSubmit: 1304 Solved: 439 Description 给定n个字符串(S1,S2,„,Sn),要求找 ...
- BZOJ1195 [HNOI2006]最短母串 【状压dp】
题目 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串. 输入格式 第一行是一个正整数n(n<=12),表示给定的字符串的 ...
- Bzoj1195 [HNOI2006]最短母串 [AC自动机]
Time Limit: 10 Sec Memory Limit: 32 MBSubmit: 1304 Solved: 439 Description 给定n个字符串(S1,S2,„,Sn),要求找 ...
- BZOJ1195 [HNOI2006]最短母串 AC自动机 bfs
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 传送门 - BZOJ1195 题意概括 给出一堆串,然后求一个包含这些串的所有串的最短的中的字典序最小的. 题解 先造一个AC ...
- BZOJ1195 HNOI2006最短母串(状压dp)
按照子串出现的先后考虑.令f[i][j]为已经出现的字符串集合为i,最后一个出现的字符串为j时的最短串长,预处理一下任意两个串的最长重叠长度,转移显然.有点麻烦的是字典序,强行增加代码难度. 另一个比 ...
- [BZOJ1195]:[HNOI2006]最短母串(AC自动机+BFS)
题目传送门 题目描述 给定n个字符串(S1,S2,…,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,…,Sn)都是T的子串. 输入格式 第一行是一个正整数n,表示给定的字符串的个数 ...
- BZOJ1195: [HNOI2006]最短母串(Trie图,搜索)
Description 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串. Input 第一行是一个正整数n(n<=12) ...
随机推荐
- bzoj 1024 [ SCOI 2009 ] 生日快乐 —— 递归
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1024 因为每次把一块切成两块,所以可以枚举从哪里切开,然后递归求解: 一开始用了不太对的贪心 ...
- Wireshark抓取RTP包,还原语音
最近在做基于SIP的VoIP通信研究,使用Wireshark软件可以对网络流量进行抓包. VoIP使用RTP协议对语音数据进行传输,语音载荷都封装在RTP包里面.要对传输中的语音进行截获和还原,需要通 ...
- pair类型 这次遇到了,记录下来,方便彼此xue习
首先,这个pair类型是在头文件utility.h中. 一个piar保存两个数据成员,是用来生成特定类型的模板,当创建一个pair时,我们必须提供两个类型名,pair的数据成员将具有对应的类型,两个类 ...
- Too Many open files 问题排查
问题描述:使用netty做性能测试时,并发过大造成Too Many open files问题 该类错误是因为linux系统对socket连接时需要打开的文件句柄数有限制可以通过ulimit -a 查看 ...
- DotnetCore安装介绍
微软的DotnetCore发布至今,已经有段时间了,我们都非常关注我们它能为我们带来什么,我们能通过它做什么?要解决这些问题,不仅仅需要基本的了解意外,还需要知道是开发环境是怎么搭建的,接下来我们就一 ...
- .Net Core添加分布式Session
一.Session HTTP是一个无状态协议,Web服务器将每一个请求都视为独立请求.并且不保存之前请求中用户的值. Session 状态是ASP.NET Core提供的一个功能,它可以在用户通应用访 ...
- 【HTTP】长连接和短连接
1. HTTP协议与TCP/IP协议的关系 HTTP的长连接和短连接本质上是TCP长连接和短连接.HTTP属于应用层协议,在传输层使用TCP协议,在网络层使用IP协议.IP协议主要解决网络路由和寻址问 ...
- 努比亚 Z17s (Nubia NX595J) 解锁BootLoader 并刷入recovery ROOT
首先下载好工具链接:https://pan.baidu.com/s/1nw7BoZB 密码:zuun 备用下载链接:https://pan.baidu.com/s/1c3mUQGg 本篇教程教你如何傻 ...
- 大型工程多个目录下的Makefile写法
1.前言 目前从事于linux下程序开发,涉及到多个文件,多个目录,这时候编译文件的任务量比较大,需要写Makefile.关于Makefile的详细内容可以参考网上流传非常广泛的<跟我一起写Ma ...
- CorelDRAW2019版本下载,CorelDRAW最新版新增功能(全)
使用CorelDRAW 2019,随时随地进行设计创作.无论您使用的是 Windows 或 Mac,都能在为您的平台量身设计的直观界面中,随心所欲地自由创作.无论您是热衷于像素,执迷于无缝输出或沉浸于 ...