POJ2004 Mix and build Trie树? dp?
学习Trie树中,所以上网搜一下Trie树的题,找到这个,人家写着是简单dp,那我就想着能学习到什么Trie树上的dp,但最后发现根本好像跟Trie树没有什么联系嘛...
题意就是给你很多个字符串(长度<20),然后如果两个字符串在排序完后,左边的一个+一个字符能变成右边的,这两个字符串连上一条边,然后求最长的边.我想了半天怎么跟Trie不搭边... 一个自然的想法是这样的,记d[i]为序号为i的字符串作为结束字符串的最长长度,我先把所有字符串根据长度由小到大排序,然后对每个字符串k,我每次把起中一个字符去掉,看这个新字符串j存不存在,如果存在d[k]=max(d[k],d[j]+1).然后记下最大的那个,递归打印一下好.如果非要用Trie那就是实现一个基本的插入查找的功能,这个哈希可能比它快多了,实在不行map也是可以的.不过Trie应该快过map.既然学习这个我就当作练下手吧...最近这两天都是RE..姿势不对呀
#include<iostream>
#include<cstring>
#include<string>
#include<algorithm>
#include<cstdio>
#define maxn 10000
using namespace std; struct StrNode
{
char sd[25];
char s[25];
int id;
bool operator < (const StrNode &b) const
{
return strlen(this->sd)<strlen(b.sd);
}
}str[maxn+50]; int d[maxn+50]; // 记下最大的距离
int prevv[maxn+50]; // 记下最大的上一个的那个 struct TrieNode
{
TrieNode *next[26];
int id;
}T[30*maxn],*Trie;
int trietop;
void insert(char *s,int idx)
{
int len=strlen(s);TrieNode *p=Trie;
for(int i=0;i<len;++i){
if(p->next[s[i]-'a']!=NULL){
p=p->next[s[i]-'a'];
}
else{
memset(T[trietop].next,0,sizeof(T[trietop].next));T[trietop].id=-1;
p->next[s[i]-'a']=&T[trietop++];
p=p->next[s[i]-'a'];
}
}
p->id=idx;
}
int find(char *s)
{
int len=strlen(s);TrieNode *p=Trie;
for(int i=0;i<len;++i){
if(p->next[s[i]-'a']!=NULL){
p=p->next[s[i]-'a'];
}
else{
return -1;
}
}
return p->id;
} int query(char *s)
{
char tmp[25];int len=strlen(s);int cnt=0;
int ret=-1,maxd=-1;
for(int i=0;i<len;++i){
cnt=0;
for(int j=0;j<len;++j){
if(i!=j) tmp[cnt++]=s[j];
}
tmp[cnt]='\0';
int tret=find(tmp);
if(tret!=-1&&d[tret]>maxd){
ret=str[tret].id;
maxd=d[tret];
}
}
return ret;
} void print(int x)
{
if(prevv[x]!=-1){
print(prevv[x]);
}
printf("%s\n",str[x].s);
} int main()
{
trietop=0;memset(T[trietop].next,0,sizeof(T[trietop].next));T[trietop].id=-1;Trie=&T[trietop++];
int n=0;char ins[25];memset(prevv,-1,sizeof(prevv));
while(scanf("%s",ins)!=EOF)
{
strcpy(str[n].sd,ins);
strcpy(str[n].s,ins);
sort(str[n].sd,str[n].sd+strlen(str[n].sd));
++n;
}
sort(str,str+n);for(int i=0;i<n;++i) str[i].id=i;
insert(str[0].sd,0);d[0]=0; int maxid=0,maxdist=0;
for(int i=1;i<n;++i){
int px=query(str[i].sd);
if(px!=-1){
d[i]=d[px]+1;prevv[i]=px;
if(d[i]>maxdist){
maxid=i;
maxdist=d[i];
}
}
else {
d[i]=0;
}
insert(str[i].sd,i);
}
print(maxid);
return 0;
}
POJ2004 Mix and build Trie树? dp?的更多相关文章
- LA-3942(trie树+dp)
题意: 给出一个由多个不同单词组成的字典,和一个长字符串,把这个字符串分解成若干个单词的连接,问有多少种方法; 思路: dp[i]表示s[i,L]的方案数,d[i]=∑d[j];s[i,j-1]是一个 ...
- NBUT 1222 English Game(trie树+DP)
[1222] English Game 时间限制: 1000 ms 内存限制: 131072 K 问题描写叙述 This English game is a simple English words ...
- Remember the Word,LA3942(Trie树+DP)
Trie树基础题,记录下代码. #include <cstdio> #include <cstring> #define MaxNode 4005*100 #define No ...
- BZOJ1212[HNOI2004]L语言——trie树+DP
题目描述 标点符号的出现晚于文字的出现,所以以前的语言都是没有标点的.现在你要处理的就是一段没有标点的文章. 一段文章T是由若干小写字母构成.一个单词W也是由若干小写字母构成.一个字典D是若干个单词的 ...
- hdu4843(NOI2000) 古城之谜 (trie树+DP)
Description 著名的考古学家石教授在云梦高原上发现了一处古代城市遗址.让教授欣喜的是在这个他称为冰峰城(Ice-Peak City)的城市中有12块巨大石碑,上面刻着用某种文字书写的资料,他 ...
- 【10.29校内测试】【线段树】【DP】【二进制Trie树求最小值最大】
Solution 标程太暴力惹QAQ 相当于是26棵线段树的说QAQ 不过我写了另一种写法,从大到小枚举每一个字母,标记字典序在这个字母之上的位置为1,每次都建一棵线段树,维护1的数量,即区间和. 修 ...
- Codeforces 615C Running Track(DP + Trie树)
题目大概说给两个串,问最少要用多少个第一个串的子串(可以翻转)拼成第二个串. UVa1401,一个道理..dp[i]表示前缀i拼接成功所需最少的子串,利用第一个串所有子串建立的Trie树往前枚举转移. ...
- UVa1401 Remember the Word(DP+Trie树)
题目给定一个字符串集合有几种方式拼成一个字符串. dp[i]表示stri...strlen-1的方案数 dp[len]=1 dp[i]=∑dp[j](stri...strj-1∈SET) 用集合的字符 ...
- Mix and Build(简单DP)
Mix and Build Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 3936 Accepted: 1203 Case Ti ...
随机推荐
- js 函数的调用模式
1.函数调用 调用一个函数将暂停当前函数的执行,传递控制权和参数给新函数.除了函数声明时定义的形参,每个函数还接受两个附加的参数:this和arguments(arguments并不是一个真正的数组, ...
- 了解GDAL的图像处理/Python
GDAL是一个操作各种栅格地理数据格式的库.包括读取.写入.转换.处理各种栅格数据格式(有些特定的格式对一些操作如写入等不支持).它使用了一个单一的抽象数据模型就支持了大多数的栅格数据(GIS对栅格, ...
- c++学习——类成员的访问权限
成员的访问权限 Public: 任何人,尤其是那些要使用这个类库的客户程序员,都能访问那个紧跟在public 后面声明的成员. 默认的package: 在同一个目录里面的文件,并且都没有明确指明它是属 ...
- Cllimbing Stairs [LeetCode 70]
1- 问题描述 You are climbing a stair case. It takes n steps to reach to the top. Each time you can eithe ...
- 【风马一族_Android】Android学习
如果是色彩盲,请自行收藏这个网站:Material Design Color Palette Generator 所有书上的UI部分扫一遍就行了,我相信现在还没有书按material design标准 ...
- if语句代码优化
if($sum==7){ $sz+=135; }elseif($sum==5){ $sz+=80; }elseif($sum==6){ $sz+=97; }elseif($sum==4){ $sz+= ...
- linux命令行解析函数介绍
函数原型: int getopt(int argc,char * const argv[ ],const char * optstring); 给定了命令参数的数量 ( ...
- 下载服务器dll文件并动态加载
1.新加一个类库 namespace ClassLibrary1 { public class Class1 { public int Add(int a, int b) { return a + b ...
- PHP中数组排序实例学习
先介绍下php中用于数组排序的函数: 排序方法 升序 降序 ...
- 原始套接字的简单tcp包嗅探
原始套接字 sock_raw = socket(AF_INET , SOCK_RAW , IPPROTO_TCP); while(1) { data_size = recvfrom(sock_raw ...