今天本來是要做一個全站程序的替換,想到了前兩天看到的SimpleStringSearch,就看了一下,結果全站程序替換沒有做成,把這個研究了一下。
我用dox作了一個chm的文檔(點擊下載),后來發(fā)現(xiàn)光看文檔是沒有用的。因為我不知道其中的數(shù)據(jù)結構組織,原來也沒有做過相關的方面內(nèi)容。
于是我修改了一下源代碼,打印了一下信息,終于搞清楚他的數(shù)據(jù)組織。
首先看一下類的繼承關系,重要的數(shù)據(jù)結構就是,檢索樹結構。其中SearchTreeNode是接口,AbstractSearchTreeNode是下邊繼承的抽象類,具體的實現(xiàn)包括ExactSearchTreeNode,SingleWildcardSearchTreeNode和WildcardSearchTreeNode。
以成員變量形式存儲的數(shù)據(jù)主要存儲在AbstractSearchTreeNode,因此我添加的打印代碼,也放在了AbstractSearchTreeNode中。
?1
public?String?toString(){
?2
????????StringBuffer?buffer?=?new?StringBuffer();
?3
????????
?4
????????buffer.append("Depth:"+depth+"\t");
?5
????????buffer.append("Children?num:"+children.size());
?6
????????buffer.append("\t"+"Character:"+character+"\n");
?7
????????depth++;
?8
????????for(int?i=0?;?i<children.size();?i++){
?9
????????????SearchTreeNode?stn?=?children.get(i);
10
????????????buffer.append(stn.toString());
11
????????}
12
????????depth--;
13
????????return?buffer.toString();
14
????}
depth是一個static的記錄層次的int變量。
?2

?3

?4

?5

?6

?7

?8

?9

10

11

12

13

14

下面是測試代碼:
?1
public?static?void?main(String[]?args)?{????????????????
?2
????????????try{
?3
????????????????????StringSearch?s?=?new?StringSearch();
?4
????????????????????MyHitHandler?handler?=?new?MyHitHandler();??????????????????
?5
????????????????????s.addSearchTerm("do",?handler);?????????????????
?6
????????????????????s.addSearchTerm("Java",?handler);
?7
????????????????????s.addSearchTerm("ava",handler);
?8
????????????????????s.addSearchTerm("da",handler);
?9
????????????????????System.out.println(s.getRoot().to2String());
10
//????????????????????s.getRoot().printString();
11
????????????????????s.search("Do,?or?do?not.?Except?in?Java.?--?Yoda");
12
????????????????????System.out.println("Count?is:?"?+?handler.getCount());
13
????????????}
14
????????????catch(IOException?ex){
15
????????????????????ex.printStackTrace();
16
????????????}
17
????}

?2

?3

?4

?5

?6

?7

?8

?9

10

11

12

13

14

15

16

17

把這幾項弄到StringSearch里邊以后,形成了一個如下的二叉樹。?
這里就可以看得很清楚了。
在根節(jié)點下邊,沒有進行排序,而在底下的每個節(jié)點下,都是按照要檢索的字符串順序排列的二叉檢索樹,因此不是一種標準的二叉檢索樹,而是字符順序相關的檢索。