<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

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

    首先看一下類的繼承關系,重要的數據結構就是,檢索樹結構。其中SearchTreeNode是接口,AbstractSearchTreeNode是下邊繼承的抽象類,具體的實現包括ExactSearchTreeNode,SingleWildcardSearchTreeNode和WildcardSearchTreeNode。
    以成員變量形式存儲的數據主要存儲在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?
    這里就可以看得很清楚了。
    在根節點下邊,沒有進行排序,而在底下的每個節點下,都是按照要檢索的字符串順序排列的二叉檢索樹,因此不是一種標準的二叉檢索樹,而是字符順序相關的檢索。

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

    主站蜘蛛池模板: 国产一级理论免费版| 最近中文字幕国语免费完整| 韩国18福利视频免费观看| 亚洲精品乱码久久久久久下载 | 91亚洲自偷手机在线观看| 久久久久国产免费| 亚洲成在人天堂一区二区| 国产免费无码AV片在线观看不卡| 综合亚洲伊人午夜网| 免费一级毛片在线播放视频| 亚洲av中文无码乱人伦在线r▽| 青柠影视在线观看免费高清| 亚洲AV日韩AV永久无码久久| 99蜜桃在线观看免费视频网站| 亚洲福利电影一区二区?| 精品女同一区二区三区免费站| 亚洲国产午夜电影在线入口| 成人免费福利电影| 精品无码专区亚洲| 中文字幕亚洲无线码a| 99久久国产免费-99久久国产免费 99久久国产免费中文无字幕 | 亚洲av无码成人精品区| 久久不见久久见免费影院www日本| 亚洲高清国产拍精品26U| 91免费播放人人爽人人快乐| 亚洲AV无码男人的天堂| 久久久久亚洲爆乳少妇无| 久久国产乱子伦精品免费看| 77777亚洲午夜久久多喷| 国产免费怕怕免费视频观看| 中国极品美軳免费观看| 亚洲成人高清在线观看| 日韩精品亚洲专区在线观看| 好紧我太爽了视频免费国产| 亚洲 欧洲 视频 伦小说| 国产精品亚洲产品一区二区三区 | 亚洲精品无码久久久久YW| 亚洲无码在线播放| 成年美女黄网站18禁免费| 一个人看的免费高清视频日本 | 亚洲性天天干天天摸|