posts - 23,comments - 66,trackbacks - 0
          by lostfire

          今天本來是要做一個全站程序的替換,想到了前兩天看到的SimpleStringSearch,就看了一下,結(jié)果全站程序替換沒有做成,把這個研究了一下。
          我用dox作了一個chm的文檔(點擊下載),后來發(fā)現(xiàn)光看文檔是沒有用的。因為我不知道其中的數(shù)據(jù)結(jié)構(gòu)組織,原來也沒有做過相關(guān)的方面內(nèi)容。
          于是我修改了一下源代碼,打印了一下信息,終于搞清楚他的數(shù)據(jù)組織。

          首先看一下類的繼承關(guān)系,重要的數(shù)據(jù)結(jié)構(gòu)就是,檢索樹結(jié)構(gòu)。其中SearchTreeNode是接口,AbstractSearchTreeNode是下邊繼承的抽象類,具體的實現(xiàn)包括ExactSearchTreeNode,SingleWildcardSearchTreeNode和WildcardSearchTreeNode。
          以成員變量形式存儲的數(shù)據(jù)主要存儲在AbstractSearchTreeNode,因此我添加的打印代碼,也放在了AbstractSearchTreeNode中。
          ?1public?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變量。

          下面是測試代碼:
          ?1public?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????}

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

          posted on 2006-06-04 02:20 rd2pm 閱讀(1280) 評論(0)  編輯  收藏 所屬分類: other

          主站蜘蛛池模板: 万盛区| 丁青县| 海城市| 册亨县| 宣威市| 阳西县| 灵石县| 融水| 绥棱县| 三江| 临江市| 江油市| 榆林市| 崇信县| 黑山县| 邳州市| 古田县| 天全县| 新丰县| 连平县| 松潘县| 宁远县| 汕头市| 舒城县| 寿宁县| 土默特左旗| 巴楚县| 南川市| 黑龙江省| 娱乐| 房山区| 广州市| 图木舒克市| 山西省| 葵青区| 凤城市| 开封县| 英吉沙县| 湖南省| 彝良县| 南投市|