概述
-
总TimeLimit:
- 1000ms
- 65536kB
-
Description
-
一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carbon"的字串是: "c", "ca", "car","carb", "carbo", 和 "carbon"。注意到这里我们不认为空串是字串, 但是每个非空串是它自身的字串.我们现在希望能用前缀来缩略的表示单词。例如, "carbohydrate" 通常用"carb"来缩略表示. 现在给你一组单词,要求你找到唯一标识每个单词的最短前缀
在下面的例子中,"carbohydrate" 能被缩略成"carboh", 但是不能被缩略成"carbo" (或其余更短的前缀)因为已经有一个单词用"carbo"开始
一个精确匹配会覆盖一个前缀匹配,例如,前缀"car"精确匹配单词"car". 因此 "car" 是 "car"的缩略语是没有二义性的, “car”不会被当成"carriage"或者任何在列表中以"car"开始的单词.
Input
- 输入包括至少2行,至多1000行. 每行包括一个以小写字母组成的单词,单词长度至少是1,至多是20. Output
- 输出的行数与输入的行数相同。每行输出由相应行输入的单词开始,后面跟着一个空格接下来是相应单词的没有二义性的最短前缀标识符。 Sample Input
-
carbohydrate cart carburetor caramel caribou carbonic cartilage carbon carriage carton car carbonate
Sample Output
-
carbohydrate carboh cart cart carburetor carbu caramel cara caribou cari carbonic carboni cartilage carti carbon carbon carriage carr carton carto car car carbonate carbona
#include <iostream> #include <stdio.h> using namespace std; struct DTree { DTree *next[26]; int k; }*root; DTree *Creat_Node(DTree *p) { p = new DTree; for(int i=0; i<26; i++) p->next[i] = NULL; p->k = 1; return p; } void Creat(char *str) { int i=0, k; DTree *p = root, *c; while(str[i]) { k = str[i]-'a'; if(p->next[k]!=NULL) p->next[k]->k ++; else { c = Creat_Node(c); p->next[k] = c; } p = p->next[k]; i++; } } void Find(char str[]) { int i=0, x; DTree *p = root; while(str[i]&&p->k>1) { x = str[i]-'a'; p = p->next[x]; putchar(str[i]); i++; } } char str[1010][30]; int main() { int i,l=0; root = Creat_Node((root)); root->k = 2; while(gets(str[l])!=NULL&&str[l][0]) { Creat(str[l]); l++; } for(i=0; i<l; i++) { printf("%s ",str[i]); Find(str[i]); printf("n"); } return 0; }
最后
以上就是威武鱼为你收集整理的poj百练2797:最短前缀的全部内容,希望文章能够帮你解决poj百练2797:最短前缀所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复