統計難題 (字典樹)

2021-06-23 03:15:49 字數 1290 閱讀 9592

problem description

ignatius最近遇到乙個難題,老師交給他很多單詞(只有小寫字母組成,不會有重複的單詞出現),現在老師要他統計出以某個字串為字首的單詞數量(單詞本身也是自己的字首).

input

輸入資料的第一部分是一張單詞表,每行乙個單詞,單詞的長度不超過10,它們代表的是老師交給ignatius統計的單詞,乙個空行代表單詞表的結束.第二部分是一連串的提問,每行乙個提問,每個提問都是乙個字串.

注意:本題只有一組測試資料,處理到檔案結束.

output

對於每個提問,給出以該字串為字首的單詞的數量.

sample input

banana

band

beeabsolute

acmba

bband

abc

sample output

231

0

字典樹:

插入字串

1.     設定當前節點為根節點,設定當前字元為插入字串中的首個字元;

2.     在當前節點的子節點上搜尋當前字元,若存在,則將當前節點設為值為當前字元的子節點;否則新建乙個值為當前字元的子節點,並將當前結點設定為新建立的節點。.

3.     將當前字元設定為串中的下個字元,若當前字元為0,則結束;否則轉2.l

性質

根節點不包含字元,除根節點外的每乙個節點都只包含乙個字元。

從根節點到某一節點,路徑上經過的字元連線起來,為該節點對應的字串。

每個節點的所有子節點包含的字元都不相同。

#include# include#includeusing namespace std;

const int maxn=500000;

char wen[20];

struct node

}tree[maxn];

int sz=0;

void insert(char *s)

}int find(char *t)

return tree[u].tot;

}int main()

while(gets(wen))

return 0;

}

統計難題(字典樹)

description ignatius最近遇到乙個難題,老師交給他很多單詞 只有小寫字母組成,不會有重複的單詞出現 現在老師要他統計出以某個字串為字首的單詞數量 單詞本身也是自己的字首 input 輸入資料的第一部分是一張單詞表,每行乙個單詞,單詞的長度不超過10,它們代表的是老師交給ignati...

統計難題(字典樹)

ignatius最近遇到乙個難題,老師交給他很多單詞 只有小寫字母組成,不會有重複的單詞出現 現在老師要他統計出以某個字串為字首的單詞數量 單詞本身也是自己的字首 input 輸入資料的第一部分是一張單詞表,每行乙個單詞,單詞的長度不超過10,它們代表的是老師交給ignatius統計的單詞,乙個空行...

統計難題 字典樹模版

problem description ignatius最近遇到乙個難題,老師交給他很多單詞 只有小寫字母組成,不會有重複的單詞出現 現在老師要他統計出以某個字串為字首的單詞數量 單詞本身也是自己的字首 input 輸入資料的第一部分是一張單詞表,每行乙個單詞,單詞的長度不超過10,它們代表的是老師...