Search Ⅲ

フォーラム(掲示板)ルール
フォーラム(掲示板)ルールはこちら  ※コードを貼り付ける場合は [code][/code] で囲って下さい。詳しくはこちら
Search

Search Ⅲ

#1

投稿記事 by Search » 14年前

[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]ここまでつくりました

コード:


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


TAその1

Re: Search Ⅲ

#2

投稿記事 by TAその1 » 14年前

こういった掲示板ではなく、演習のTAに聞きましょう by TA

閉鎖

“C言語何でも質問掲示板” へ戻る