2797:最短前缀(题解)

原创 2016年08月30日 09:38:18


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.
输出
输出的行数与输入的行数相同。每行输出由相应行输入的单词开始,后面跟着一个空格接下来是相应单词的没有二义性的最短前缀标识符。
样例输入
carbohydrate
cart
carburetor
caramel
caribou
carbonic
cartilage
carbon
carriage
carton
car
carbonate



#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;
    }
}

C++之练习题25

1.一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carbon"的字串是:"c", "ca", "car", "carb", "carbo", 和 "carbon"。注意,这里我们不...

2797:最短前缀(c++ 字典树)

总时间限制: 1000ms 内存限制: 65536kB 描述一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carbon"的字串是: "c", "ca", "car", "carb...

poj百练2797:最短前缀

总Time Limit:  1000ms   Memory Limit:  65536kB Description 一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carb...

【解题报告】百练2797_最短前缀(字典树)

总时间限制: 1000ms 内存限制: 65536kB 描述一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carbon"的字串是: "c", "ca", "car", "carb...

求单词最短的确切前缀表示

是今天看到CareerCup上的问题: #include #include #include #include using namespace std; class WordNotFoun...

NOI题库1799 最短前缀

1799:最短前缀 总时间限制: 1000ms 内存限制: 65536kB 描述 一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 "carbon"的字串是: "c", "ca...

poj 2001 Shortest Prefixes 【字典树】【找每一个字符串在字符串集里面的 最短且可唯一标识 的前缀】

Shortest Prefixes Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 14747...

POJ 2001 Shortest Prefixes 字典树经典题,求最短唯一前缀)

Shortest Prefixes Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 18950...

字典树的简单介绍及其如何求最短前缀

Trie,又称字典树、单词查找树,是一种树形结构,用于保存大量的字符串,其核心思想是空间换时间。它的优点是:利用字符串的公共前缀来节约存储空间。 假设有b,abc,abd,bcd,abcd,efg,...

最短前缀

最短前缀总时间限制: 1000ms 内存限制: 65536kB描述 一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 “carbon”的字串是: “c”, ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:2797:最短前缀(题解)
举报原因:
原因补充:

(最多只允许输入30个字)