51nod 1526 分配笔名(Trie树+贪心)
2024-09-06 16:19:33
建出Trie树然后求出一个点子树中有多少笔名和真名。然后贪心匹配即可。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const int N=810000;
int ans,n;
char s[N];
struct trie{
int trans[N][27],tot,size[N][2],len[N];
void ins(char *s,int k){
int L=strlen(s+1);
int now=0,lon=0;
for(int i=1;i<=L;i++){
if(trans[now][s[i]-'a'+1]==0)trans[now][s[i]-'a'+1]=++tot,len[tot]=len[now]+1;
now=trans[now][s[i]-'a'+1];
}
size[now][k]++;
}
void dfs(int u){
for(int i=1;i<=26;i++){
int v=trans[u][i];
if(v==0)continue;
dfs(v);
size[u][0]+=size[v][0];
size[u][1]+=size[v][1];
}
int tmp=min(size[u][0],size[u][1]);
ans+=tmp*len[u];
size[u][0]-=tmp;size[u][1]-=tmp;
}
}trie;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%s",s+1);
trie.ins(s,0);
}
for(int i=1;i<=n;i++){
scanf("%s",s+1);
trie.ins(s,1);
}
trie.dfs(0);
printf("%d",ans);
return 0;
}
最新文章
- MD5加密的Java实现
- 使用Python进行描述性统计
- Other Linker Flags到底是什么
- [bzoj1618][Usaco2008 Nov]购买干草
- Python之路-python(面向对象进阶)
- 【knowledgebase】不要在一个很大的RDD上调用collect
- [SQL]不知道
- 《浅析各类DDoS攻击放大技术》
- Comet、SSE、Web Socket
- HW2.23
- Jack Straws(判断线段是否相交 + 并查集)
- VAO VBO IBO大乱炖
- Android 7.0(牛轧糖)新特性
- ionic2 自定义cordova插件开发以及使用 (Android)
- MySQLbase
- HTML5 Audio/Video 标签,属性,方法,事件汇总 (转)
- 团队作业7——第二次项目冲刺(Beta版本计划及安排)
- 游戏AI之感知(1)
- I/O模型系列之四:两种高性能IO设计模式 Reactor 和 Proactor
- js 执行机制
热门文章
- 浅谈AVL树,红黑树,B树,B+树原理及应用
- vscode快捷键补充
- .net基础总复习(1)
- GitHub两种上传方式的对比----SSH / https
- HDU 2256 Problem of Precision( 矩阵快速幂 )
- [CodeForces]1006F Xor Path
- eclipse引入svn插件,并将项目同步到svn
- Java分布式爬虫Nutch教程——导入Nutch工程,执行完整爬取
- eclipse project文件夹下 删除不掉文件夹或者文件的解决的方法
- 5种语言混合编程:C++、JS、python、Lisp、汇编