题意:给出n个单词(1<=n<=1000),求出每个单词的非公共前缀,如果没有,则输出自己。
思路:基础的trie。
只要基本了解Trie的构造与查找过程,就可以去做了。
代码如下所示:
#include<iostream>
using namespace std;
const int Max = 1002;
const int branchNum = 26;
struct tree_node
{
int count; // 记录用到这个节点的单词数量,如果=1,则证明其为这个单词唯一的节点。
tree_node *next[branchNum];
}root,node[20*Max];
int p = 0; // 静态建树的特点,记录用了几个tree_node,则下一个节点为node[p]。
void insert(char *word)
{
tree_node *location = &root; // 起初先指向根,再一层层向下查找。
while(*word)
{
if(location->next[*word-'a'] == NULL)
{
node[p].count = 0;// 初始化新节点
location->next[*word-'a'] = &node[p ++];
}
location = location->next[*word-'a'];
location->count ++;
word ++;
}
}
void search(char *word)
{
tree_node *location = &root;
while(*word && location)
{
if(location->count == 1)
break;
printf("%c", *word);
location = location->next[*word-'a'];
word ++;
}
printf("\n");
}
int main()
{
char word[Max][21];
int i, k = 0;
while(scanf("%s", word[k])!= EOF)
{
insert(word[k]);
k ++;
}
for(i = 0; i < k; i ++)
{
printf("%s ", word[i]);
search(word[i]);
}
return 0;
}
分享到:
相关推荐
POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类
poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题报告poj 解题...
POJ第1861题源码 POJ第1861题源码 POJ第1861题源码
北大POJ1159-Palindrome 解题报告+AC代码
poj分类poj分类poj分类poj分类
poj 3414解题报告poj 3414解题报告poj 3414解题报告poj 3414解题报告
C语言 poj npu 西工大 C语言Poj答案全完整打包,给有需要的朋友
poj 1012解题报告poj 1012解题报告poj 1012解题报告poj 1012解题报告
poj 2329解题报告poj 2329解题报告poj 2329解题报告poj 2329解题报告
poj 1659解题报告poj 1659解题报告poj 1659解题报告poj 1659解题报告
POJ1503解答 POJ1503解答,正确答案(已通过POJ)
北大POJ2002-Squares 解题报告+AC代码
POJ1048,加强版的约瑟夫问题 难度中等
POJ1083的代码,POJ1083的代码,POJ1083的代码
poj 百练 题目分类 poj 百练 题目分类
poj 1001答案
POJ2968代码有用,欢迎下载,POJ代码
POJ上的一道题目,自己写的代码,因为想下载别人的, 所以就放上了。
poj 1440解题报告 poj 1440解题报告 poj 1440解题报告 poj 1440解题报告
poj 3083解题报告poj 3083解题报告poj 3083解题报告poj 3083解题报告