poj 2797 最短前綴

2797:最短前綴
Time Limit: 1000ms          

Memory Limit:  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.

Sample Input
carbohydrate
cart
carburetor
caramel
caribou
carbonic
cartilage
carbon
carriage
carton
car
carbonate
Output

輸出的行數與輸入的行數相同。每行輸出由相應行輸入的單詞開始,後面跟着一個空格接下來是相應單詞的沒有二義性的最短前綴標識符。
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

只需要用一個三次循環來做,大循環爲輸入的第i個字符串,中層循環爲從第一個字符開始長度爲1到strlen(i)的子串

小循環爲子串與其他的第j個字符串進行比較,

初次做題的時候,採用的strstr(其餘字符串,子串)是否存在的作法,提交後爲wrong answer,考慮後得知,判斷前綴子串是否出現在其他字符串中,需要判斷這個子串是否爲其他字符串的前綴,而不僅僅判斷是否爲子串

另外,此種情況判斷是否輸入結束,可以使用判斷

while(scanf("%s",s[count])!=EOF&&source[n][count])或者while(gets(s[count])&&s[count][0])

#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int main(){
	char s[1002][22];
	char tmp[22];
	int len[1002];
	int i,j,k,count=0;
	while((scanf("%s",s[count]))!=EOF){
		len[count]=strlen(s[count]);
		count++;
	}
	for(i=0;i<count;i++){
		for(j=1;j<=len[i];j++){
			memset(tmp,0,sizeof(tmp));
			for(k=0;k<j;k++)
				tmp[k]=s[i][k];
			tmp[k]='\0';
			//cout<<tmp<<endl;
			for(k=0;k<count;k++){
				if(k!=i){
					if(strstr(s[k],tmp)==s[k])
						break;
				}
			}
			if(k==count){
				cout<<s[i]<<" "<<tmp<<endl;
				break;
			}
		}
		if(j==len[i]+1)
			cout<<s[i]<<" "<<s[i]<<endl;
	}
	return 0;
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章