Search Ⅲ
Posted: 2012年5月11日(金) 05:39
[1]質問
直接アドレス法ではなくダブルハッシュを用いて、以下の命令を実行する簡易的な「辞書」の実装方法を教えて下さい。
insert str: 辞書にstrを追加する。
find str: 辞書にstrが含まれる場合'yes'と、含まれない場合'no'と出力する。
入力ルール
最初の行に命令の数nが与えられる。続くn行にn件の命令が与えられる。命令の形式は上記のとおり。
出力ルール
各find命令について、yesまたはnoを1行に出力。
制約
与えられる文字列は、'A', 'C', 'G', 'T'の4種類の文字から構成される。
1 ≤ 文字列の長さ ≤ 12
n ≤ 1000000
入力例 1
5
insert A
insert T
insert C
find G
find A
出力例 1
no
yes
入力例 2
13
insert AAA
insert AAC
insert AGA
insert AGG
insert TTT
find AAA
find CCC
find CCC
insert CCC
find CCC
insert T
find TTT
find T
出力例 2
yes
no
no
yes
yes
yes
[2] 環境
[2.1] OS : Mac, Linux
[2.2] コンパイラ名 : gcc
[3]ここまでつくりました
直接アドレス法ではなくダブルハッシュを用いて、以下の命令を実行する簡易的な「辞書」の実装方法を教えて下さい。
insert str: 辞書にstrを追加する。
find str: 辞書にstrが含まれる場合'yes'と、含まれない場合'no'と出力する。
入力ルール
最初の行に命令の数nが与えられる。続くn行にn件の命令が与えられる。命令の形式は上記のとおり。
出力ルール
各find命令について、yesまたはnoを1行に出力。
制約
与えられる文字列は、'A', 'C', 'G', 'T'の4種類の文字から構成される。
1 ≤ 文字列の長さ ≤ 12
n ≤ 1000000
入力例 1
5
insert A
insert T
insert C
find G
find A
出力例 1
no
yes
入力例 2
13
insert AAA
insert AAC
insert AGA
insert AGG
insert TTT
find AAA
find CCC
find CCC
insert CCC
find CCC
insert T
find TTT
find T
出力例 2
yes
no
no
yes
yes
yes
[2] 環境
[2.1] OS : Mac, Linux
[2.2] コンパイラ名 : gcc
[3]ここまでつくりました
#include<stdio.h>
#include<string.h>
#define M
#define NIL (-1)
#define L 14
char H[M][L]; /* Hash Table */
int getChar(char ch){
if ( ch == 'A') return 0;
else if ( ch == 'C') return 1;
else if ( ch == 'G') return 2;
else if ( ch == 'T') return 3;
else assert(false);
}
/* convert a string into an integer value */
long long getKey(char str[]){
long long sum = 0, p = 1, i;
for ( i = 0; i < strlen(str); i++ ){
sum += p*(getChar(str[i]));
p *= 4;
}
return sum;
}
int h1(int key){ return }
int h2(int key){ return }
int find(char str[]){
}
int insert(char str[]){
}
int main(){
int i, n, h;
char str[L], com[9];
for ( i = 0; i < M; i++ ) H[i][0] = '\0';
scanf("%d", &n);
for ( i = 0; i < n; i++ ){
scanf("%s %s", com, str);
if ( com[0] == 'i' ){
insert(str);
} else {
if (find(str)){
printf("yes\n");
} else {
printf("no\n");
}
}
}
return 0;
}