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 ...
随机推荐
- 《通过脚本查看哪些ip被占用》shell笔记
改脚本查看哪些ip被占用. #!/bin/bash for i in {1..10} //赋予i变量1-10 do //干什么 ping -c1 -w1 192.168.7.$i && ...
- Logstash+kibana+ ElasticSearch+redis
这是之前Logstash+kibana+ ElasticSearch+redis 安装时,自己整理的初学者容易看懂的资料,按照以下的步骤也已经完成了安装. 这里有二台服务器: 192.168.148. ...
- [转]浅析AD Exchange——RTB模式
在上一篇文章中,我们了解了程序化购买,并且知道程序化购买的最基本的一种RTB的竞价模式,了解了DSP.SSP.Ad Exchange等概念,不清楚的同学可以看看上一篇文章<程序化购买>. ...
- java 反射的踩的一个坑
今天工作的时候用到了一个反射.其业务简单描述为:系统启动时将需要定时调用的方法签名保存到数据库中,开启线程定时从数据库中读取对应的方法签名,通过反射生成实例后调用方法.完成一定的定时任务. 写到的方法 ...
- nodejs ssh2
https://www.npmjs.com/package/ssh2 npm install ssh2 ssh2文件下载: //前台命令下发 app.get('/test/fileDownload' ...
- php多层数组与对象的转换实例代码
通过json_decode(json_encode($object)可以将对象一次性转换为数组,但是object中遇到非utf-8编码的非ascii字符则会出现问题,比如gbk的中文,何况json_e ...
- HTML表单样式
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...
- eclipse,myeclipse svn 和jadclipse 反编译插件 及安装
插件下载链接:http://download.csdn.net/download/mmyzlinyingjie/6456785 myeclipse svn 安装: 把svn解压,然后把这个文件夹放在m ...
- iis 下的 selfssl
当然,如果你想省掉所有这些麻烦也行,最简单的在IIS启动SSL的方法只要3步: 1. 下载 IIS 6.0 Resource Kit Tools: http://www.microsoft.com/d ...
- Linux之父Linus Torvalds:讨厌C++
"Linux内核的创始人Linus Torvalds最近在一封邮件中说明了内核开发需要使用C语言而非C++的理由.在庞大的项目中,人们对不是自己开发的模块并不了解,能快速理解其他模块中函数的 ...