建出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;
}

最新文章

  1. MD5加密的Java实现
  2. 使用Python进行描述性统计
  3. Other Linker Flags到底是什么
  4. [bzoj1618][Usaco2008 Nov]购买干草
  5. Python之路-python(面向对象进阶)
  6. 【knowledgebase】不要在一个很大的RDD上调用collect
  7. [SQL]不知道
  8. 《浅析各类DDoS攻击放大技术》
  9. Comet、SSE、Web Socket
  10. HW2.23
  11. Jack Straws(判断线段是否相交 + 并查集)
  12. VAO VBO IBO大乱炖
  13. Android 7.0(牛轧糖)新特性
  14. ionic2 自定义cordova插件开发以及使用 (Android)
  15. MySQLbase
  16. HTML5 Audio/Video 标签,属性,方法,事件汇总 (转)
  17. 团队作业7——第二次项目冲刺(Beta版本计划及安排)
  18. 游戏AI之感知(1)
  19. I/O模型系列之四:两种高性能IO设计模式 Reactor 和 Proactor
  20. js 执行机制

热门文章

  1. 浅谈AVL树,红黑树,B树,B+树原理及应用
  2. vscode快捷键补充
  3. .net基础总复习(1)
  4. GitHub两种上传方式的对比----SSH / https
  5. HDU 2256 Problem of Precision( 矩阵快速幂 )
  6. [CodeForces]1006F Xor Path
  7. eclipse引入svn插件,并将项目同步到svn
  8. Java分布式爬虫Nutch教程——导入Nutch工程,执行完整爬取
  9. eclipse project文件夹下 删除不掉文件夹或者文件的解决的方法
  10. 5种语言混合编程:C++、JS、python、Lisp、汇编