最短前缀
来源:互联网 发布:中央人民大学网络教育 编辑:程序博客网 时间:2024/06/05 13:02
最短前缀
总时间限制:
1000ms
内存限制:
65536kB
描述
一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 “carbon”的字串是: “c”, “ca”, “car”, “carb”, “carbo”, 和 “carbon”。注意到这里我们不认为空串是字串, 但是每个非空串是它自身的字串. 我们现在希望能用前缀来缩略的表示单词。例如, “carbohydrate” 通常用”carb”来缩略表示. 现在给你一组单词, 要求你找到唯一标识每个单词的最短前缀
在下面的例子中,”carbohydrate” 能被缩略成”carboh”, 但是不能被缩略成”carbo” (或其余更短的前缀) 因为已经有一个单词用”carbo”开始
一个精确匹配会覆盖一个前缀匹配,例如,前缀”car”精确匹配单词”car”. 因此 “car” 是 “car”的缩略语是没有二义性的 , “car”不会被当成”carriage”或者任何在列表中以”car”开始的单词.
输入
输入包括至少2行,至多1000行. 每行包括一个以小写字母组成的单词,单词长度至少是1,至多是20.
输出
输出的行数与输入的行数相同。每行输出由相应行输入的单词开始,后面跟着一个空格接下来是相应单词的没有二义性的最短前缀标识符。
样例输入
carbohydratecartcarburetorcaramelcariboucarboniccartilagecarboncarriagecartoncarcarbonate
样例输出
carbohydrate carbohcart cartcarburetor carbucaramel caracaribou caricarbonic carbonicartilage carticarbon carboncarriage carrcarton cartocar carcarbonate carbona
想法: 用一个结构体存储输入的序号,原串 ,输出的串(存储时最好下标从1开始)。将结构体按照原串的字典序排列,对于每个串对上下比较暴力分别找出与上 下不同的位置,然后将较大的设为这个串的标识符(测试的时候用control + z 终止输入)
#include<iostream>#include<algorithm>#include<cmath>#include<vector>#include<map>#include<string>#include<cstring>#include<queue>#include<stack>#include<cstdio>using namespace std;typedef long long ll;struct node{ char str[25]; int n; char ans[25];}num[1005];int flag = 1;int cmp1(node a , node b){ return strcmp(a.str , b.str) < 0;}int cmp2(node a ,node b){ return a.n < b.n;}void sov(){ for(int i = 1 ; i < flag ; ++i) { if(strcmp(num[i].str , num[i - 1].str) == 0) { strcpy(num[i].ans, num[i-1].ans); continue; } int j,s; for(j = 0 ; num[i].str[j] == num[i-1].str[j] ; ++j); for(s = 0 ; num[i].str[s] == num[i + 1].str[s] ;++s); j = max(j,s); for(int k = 0 ; k <= j ; ++k) num[i].ans[k] = num[i].str[k]; }}int main(){ while(scanf("%s" , &num[flag].str) != EOF) { num[flag].n = flag; flag++; } sort(num + 1, num + flag ,cmp1); sov(); sort(num + 1 , num + flag , cmp2); for(int i = 1 ; i < flag ; ++i) cout<<num[i].str<<" "<<num[i].ans<<endl;}
- 最短前缀
- 06:最短前缀
- poj 2797 最短前缀
- 2797:最短前缀(题解)
- nkoj 1930 最短前缀
- poj百练2797:最短前缀
- 百练 2797:最短前缀
- NOI题库1799 最短前缀
- 百炼 2797:最短前缀
- 最短前缀(字典树)
- 字典树 06:最短前缀
- 第4章练习题--7--最短前缀--2797
- 最短的名字+csuoj+前缀树(字典树)
- 求单词最短的确切前缀表示
- uvalive 3026 Period (前缀最短循环节)
- 2797:最短前缀(c++ 字典树)
- POJ Shortest Prefixes -- 最短前缀问题 -- 字典树
- 竞赛题目讲解-【Rocky Mountain 2004】最短前缀
- Java与JSTL变量交互
- “深入理解”—选择排序算法
- LeetCode - 242. Valid Anagram
- iOS性能优化-TableView
- 剑指offer----数字在排序数组中出现的次数----java实现
- 最短前缀
- HTML标签以及各个标签属性大全
- C++11中的进行线程同步的方法
- 为什么要重写toString()方法
- 初涉MySQL操作(一)
- matlab移位运算
- 快速幂(普通快速幂、矩阵快速幂)
- c# java 比较
- 通俗易懂细说坐标系、投影