青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

linux&c++ R&D

programing is a pleasure!

A simple application example of binary tree structure

Binary Tree is  widely  employed in many cases as a very important data structrue.
I will take a simple example to introduce it.
Suppose we want to handle the more general problem of counting the occurrences of all the
words in some input.Since the list of words isn't known in advance,we can't conveniently sort it and use a binary search.Yet we can't do a linear search for each word as it arrives,to see if it's already been seen;the program would take a long time.
a binary tree will help us to solve the problem.
terminal:
First we define the node structure,which is used to store the infomation of each word.
it consists of word name,count,two pointer,which point to left subtree and right substree.
 secondly,tree structure is a binary sorted tree.
each word has a unique node in the tree.
the detailed code implemention below:

// wordTree.h: interface for the wordTree class.
//
//////////////////////////////////////////////////////////////////////
#ifndef        __WORDTREE_
#define        __WORDTREE_

class wordTree;


class wordNode{
friend 
class wordTree;
private:
   
char *word;
   
int count;
   wordNode 
*left,*right;
private:
   wordNode(
const char* w,wordNode *left=0,wordNode *right=0,int count=1);
   
~wordNode();
    inline 
void incrcount(){
        count
++;
    }

}
;
class wordTree  
{
 
public:
    wordTree():root(
0){
        
    }

    virtual 
~wordTree(){
        freetree(root);
    }

    
void addWord(const char *w);
    
void printTree();
private:
    wordNode
* addWord(wordNode *p,const char *w);
    
void printTree(wordNode *p);
    
void freetree(wordNode *p);
    wordNode
* root;
}
;

#endif 
// end __WORDTREE_

 

// wordTree.cpp: implementation of the wordTree class.
//
//////////////////////////////////////////////////////////////////////

#include 
"wordTree.h"
#include 
<string.h>
#include 
<iostream>


wordNode::wordNode(
const char* w,wordNode *left/* =0 */,wordNode *right/* =0 */,int count/* =0 */)
{
  
int len=strlen(w);
  word
=new char[len+1];
  strcpy(word,w);
  
  
this->left=left;
  
this->right=right;
  
this->count=count;

}

wordNode::
~wordNode()
{
    
if(word!=0)
        delete [] word;
}




void wordTree::addWord(const char *w){

    root
=addWord(root,w);

}

wordNode
* wordTree::addWord(wordNode *p,const char *w)
{
 
int cond;
 
if(p==0)
     p
=new wordNode(w);
  
else if((cond=strcmp(w,p->word))==0)
      p
->incrcount();
 
  
else if (cond<0)
      p
->left=addWord(p->left,w);
  
else
      p
->right=addWord(p->right,w);
  
return p;
}

void wordTree::printTree()
{
  printTree(root);
 }

void wordTree::printTree(wordNode *p)
{
 
if (p==0)
     
return;
 printTree(p
->left);
 std::cout
<<p->word<<"  count:  "<<p->count<<std::endl;
 printTree(p
->right);
}

void wordTree::freetree(wordNode *p)
{
  
if(p==0)
      
return;
  freetree(p
->left);
  freetree(p
->right);
  delete p;

}

 

//test.cpp
//test the example

#include 
"wordTree.h"
#include 
<iostream>
#include 
<string>
int main()
{
 wordTree wt;
 std::string str;
 
while (std::cin>>str)
 
{
   wt.addWord(str.c_str());
   wt.printTree();
 }


 

}

       

posted on 2007-05-17 13:17 丑石 閱讀(249) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


My Links

Blog Stats

News

常用鏈接

留言簿(1)

隨筆分類(13)

隨筆檔案(17)

文章檔案(1)

相冊

收藏夾(1)

Friends' blog

useful sites

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久999国产| 亚洲在线视频免费观看| 久久色中文字幕| 精品va天堂亚洲国产| 久久亚洲风情| 久久女同精品一区二区| 激情五月婷婷综合| 欧美二区在线观看| 欧美精品在线免费播放| 亚洲一区欧美一区| 亚洲在线观看免费| 国外成人免费视频| 欧美成人一品| 欧美日韩午夜在线| 先锋影音网一区二区| 欧美一区二区视频免费观看| 国产亚洲成精品久久| 久久中文字幕一区| 欧美激情一区二区三区高清视频| 一区二区三区四区精品| 亚洲在线中文字幕| 在线看日韩av| 99精品福利视频| 国产亚洲免费的视频看| 久久综合五月| 欧美视频亚洲视频| 久久频这里精品99香蕉| 欧美欧美午夜aⅴ在线观看| 亚洲欧美www| 久久亚洲一区| 亚洲欧美日韩国产中文| 久久久久久久一区| 亚洲午夜未删减在线观看| 亚洲乱码视频| 亚洲制服丝袜在线| 亚洲精品免费网站| 欧美伊人久久久久久午夜久久久久 | 久久综合婷婷| 欧美日韩午夜| 免费视频一区| 国产精品有限公司| 亚洲国产高清一区| 国产欧美在线观看| 日韩图片一区| 亚洲激情社区| 欧美一区二区日韩一区二区| 99精品视频一区二区三区| 久久精品国产一区二区三 | 欧美视频在线不卡| 男女精品网站| 国产香蕉久久精品综合网| 亚洲精品久久久久久久久久久久 | 久久夜色精品亚洲噜噜国产mv | 国产日韩欧美一区二区三区四区| 亚洲国产高清一区二区三区| 国产伦理一区| 在线一区亚洲| 一区二区三区四区五区精品视频 | 亚洲美女电影在线| 亚洲国产欧美一区二区三区同亚洲 | 欧美激情中文字幕一区二区| 国产日韩三区| 亚洲免费视频成人| 午夜久久一区| 国产精品久久久久三级| 亚洲毛片在线| 在线综合亚洲欧美在线视频| 欧美精品一区二区三| 欧美激情一区二区三区不卡| 在线欧美小视频| 葵司免费一区二区三区四区五区| 久久天天躁狠狠躁夜夜爽蜜月| 国产日韩精品入口| 欧美在线啊v一区| 久久国产精品一区二区三区四区 | 久久精品一区四区| 久久久精品日韩| 国产一区二区精品| 久久国产一区二区三区| 久久久精品午夜少妇| 国精产品99永久一区一区| 另类图片国产| 怡红院精品视频| 久久永久免费| 亚洲国产mv| 亚洲视频播放| 国产精品一区=区| 欧美在线首页| 亚洲第一搞黄网站| 一区二区不卡在线视频 午夜欧美不卡'| 美女国产精品| 99热精品在线| 久久久999精品免费| 狠狠久久亚洲欧美专区| 欧美大胆成人| 一本色道久久88综合亚洲精品ⅰ | 亚洲毛片在线| 欧美色道久久88综合亚洲精品| 亚洲无毛电影| 巨乳诱惑日韩免费av| 亚洲精品少妇网址| 国产精品色一区二区三区| 久久精品国产久精国产一老狼| 欧美国产日本在线| 亚洲自啪免费| 在线观看精品| 国产精品九色蝌蚪自拍| 久久久综合精品| 99成人免费视频| 久久亚洲私人国产精品va| 日韩一级黄色片| 国内视频一区| 欧美视频专区一二在线观看| 久久久999成人| 中文日韩欧美| 亚洲区一区二| 老**午夜毛片一区二区三区| 一区二区三区成人| 一区在线观看视频| 国产精品久久一级| 欧美高清一区二区| 久久精品中文字幕免费mv| 日韩午夜免费视频| 欧美激情欧美狂野欧美精品| 久久精品国产99国产精品| 99国产精品视频免费观看| 伊人精品视频| 国产日产欧美一区| 国产精品成人播放| 欧美久久一区| 欧美国产精品一区| 榴莲视频成人在线观看| 久久爱91午夜羞羞| 亚洲欧美日本伦理| 中文一区二区| 一本色道88久久加勒比精品| 亚洲国产欧美一区二区三区丁香婷| 久久久久国产一区二区三区| 亚洲欧美精品伊人久久| 一区二区日韩欧美| 亚洲免费观看高清在线观看| 亚洲国产99| 亚洲电影毛片| 亚洲国产精品欧美一二99| 好看的日韩av电影| 伊人久久综合97精品| 韩国一区二区在线观看| 国产一区二区三区久久精品| 国产色综合天天综合网| 国产麻豆精品theporn| 国产欧美日韩精品一区| 国产亚洲免费的视频看| 国产亚洲人成网站在线观看| 国产一区视频在线观看免费| 国产日韩高清一区二区三区在线| 国产日韩欧美视频| 国模大胆一区二区三区| 伊人夜夜躁av伊人久久| 在线欧美不卡| 亚洲美女免费精品视频在线观看| 亚洲欧洲一区二区三区在线观看| 亚洲精品国产日韩| 一区二区欧美日韩视频| 亚洲综合丁香| 久久大综合网| 亚洲精品免费网站| 日韩一级大片| 亚洲欧美成人在线| 久久国产精品高清| 欧美成人a视频| 亚洲欧洲一区二区在线播放| 亚洲美女淫视频| 性久久久久久久久| 麻豆精品国产91久久久久久| 欧美精品一区二区三| 国产精品自拍一区| 在线观看视频欧美| 亚洲午夜国产成人av电影男同| 篠田优中文在线播放第一区| 麻豆精品精品国产自在97香蕉| 欧美黄色视屏| 亚洲在线一区二区| 免费短视频成人日韩| 国产精品成人午夜| 在线成人av.com| 亚洲制服少妇| 免费短视频成人日韩| 99国产精品国产精品久久| 久久av资源网| 欧美日韩一二三区| 一区二区视频免费在线观看| 一区二区国产在线观看| 久久野战av| 正在播放亚洲一区| 免费高清在线一区| 国产欧美一区二区三区另类精品 | 在线视频精品一区| 狂野欧美激情性xxxx欧美| 亚洲美女网站| 玖玖玖免费嫩草在线影院一区|