2797:最短前缀(题解)
来源:互联网 发布:简单的二进制算法 编辑:程序博客网 时间:2024/06/05 18:33
2797:最短前缀
- 查看
- 提交
- 统计
- 提示
- 提问
- 总时间限制:
- 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
#include<stdio.h>#include<iostream>using namespace std;#define N 1010#define M 25#include<string.h>int main(){ char a[N][M],temp[M]; int len[N],count=0,k,i,j; while(gets(a[count])){ if(a[count][0]=='\0') //gets遇到换行会自动转化成\0 break; else{ len[count]=strlen(a[count]); //使用一个数组保留每个输入字符串的长度,后面比较时不用你每次都求长度 count++; // } } for(i=0;i<count;i++){ //挨个查找每个单词的唯一前缀 for(j=1;j<=len[i];j++){ //挨个查找该字符串的前缀是否唯一标示,注意子串长度从1开始,空串不是子串 for(k=0;k<j;k++){ temp[k]=a[i][k]; } temp[j]='\0';//使用temp数组暂时保存要判断是否唯一的子串 for(k=0;k<count;k++){ if(k!=i){//判断子串是否是其他字符串的字符串 if(strstr(a[k],temp)==a[k]) break; } } if(k==count){//若果不是打印,跳出循环找下一个串的表一最短前缀 cout<<a[i]<<" "<<temp<<endl; break; }
} if(j==len[i]+1)//如果字符串本身也是其他串的子串则打印该串本身 cout<<a[i]<<" "<<a[i]<<endl; }}
0 0
- 2797:最短前缀(题解)
- poj 2797 最短前缀
- poj百练2797:最短前缀
- 百练 2797:最短前缀
- 百炼 2797:最短前缀
- 最短前缀
- 06:最短前缀
- nkoj 1930 最短前缀
- 第4章练习题--7--最短前缀--2797
- 2797:最短前缀(c++ 字典树)
- 最短回文串 题解
- NOI题库1799 最短前缀
- 最短前缀(字典树)
- 字典树 06:最短前缀
- 【解题报告】百练2797_最短前缀(字典树)
- 【题解】最短路径四题
- CSU1115 最短的名字 题解
- 最短路径变型题解法举例
- 【Swift】导航栏隐藏底部黑线
- Java并发编程:Callable、Future和FutureTask -----ksoap 里面的解释
- haproxy nginx 多路径
- VR、AR、MR和CR分别是什么?
- 指定行合并为一行
- 2797:最短前缀(题解)
- Linux 下安装python软件包(pip、nose、virtualenv、distribute )
- Android性能优化之一
- A session had already been started - ignoring session_start()
- 1089. Insert or Merge (25)
- Codeforces Round #369 (Div. 2)
- LeetCode 42 Trapping Rain Water
- MySQL锁定状态查看命令
- numpy.flatten() 与 numpy.ravel()的区别