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

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 丑石 閱讀(245) 評論(0)  編輯 收藏 引用

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>
            久久久国产精品一区| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲免费在线| 国产日韩欧美综合| 久久婷婷色综合| 美女视频黄a大片欧美| 日韩一二三区视频| 亚洲视频在线看| 国产主播一区二区| 亚洲激情国产| 欧美色另类天堂2015| 欧美综合77777色婷婷| 久久婷婷综合激情| 在线亚洲精品| 久久精品国产亚洲一区二区| 亚洲理论在线| 性欧美1819sex性高清| 亚洲激情专区| 亚洲欧美一区二区三区在线| 亚洲国产欧美另类丝袜| 日韩午夜在线| 伊人久久大香线蕉综合热线| 99热在这里有精品免费| 黄色精品免费| 亚洲小说欧美另类婷婷| 91久久精品www人人做人人爽 | 99日韩精品| 亚洲电影毛片| 亚洲欧美春色| 日韩一二三区视频| 久久精品国产久精国产思思| 宅男噜噜噜66国产日韩在线观看| 久久精品国产亚洲精品| 亚洲中字黄色| 欧美精品一区二区三区久久久竹菊| 性做久久久久久久免费看| 欧美激情视频一区二区三区免费| 欧美在线资源| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 亚洲三级色网| 久久精品日韩| 久久国产精品毛片| 国产精品国产精品国产专区不蜜| 亚洲电影专区| 在线免费观看欧美| 久久精品视频一| 欧美有码在线视频| 国产精品国产| 在线亚洲成人| 在线视频亚洲一区| 欧美日韩精品二区第二页| 亚洲福利免费| 亚洲乱码国产乱码精品精天堂 | 亚洲欧洲一区二区天堂久久| 久久国产精品色婷婷| 亚洲欧美在线视频观看| 欧美日韩视频在线一区二区| 亚洲激情在线| av成人手机在线| 欧美久久久久| 99精品欧美一区| 亚洲午夜精品久久久久久浪潮 | 免费人成精品欧美精品| 老司机一区二区三区| 黄色国产精品| 免费成年人欧美视频| 亚洲国产日韩在线一区模特| 亚洲美女av电影| 欧美日韩国产电影| 亚洲视频在线观看| 久久成人精品无人区| 国产亚洲一区二区三区在线观看| 欧美一区二区久久久| 久久女同互慰一区二区三区| 国内精品美女在线观看| 老鸭窝91久久精品色噜噜导演| 欧美 日韩 国产 一区| 亚洲欧洲中文日韩久久av乱码| 欧美成人xxx| 一本一道久久综合狠狠老精东影业| 亚洲一区二区高清视频| 国产亚洲福利一区| 狂野欧美一区| 99在线热播精品免费99热| 亚洲欧美日本国产专区一区| 国产亚洲欧洲一区高清在线观看| 久久人91精品久久久久久不卡 | 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲国产一二三| 国产精品成人午夜| 久久久精品午夜少妇| 亚洲精品中文字幕女同| 久久精品国产亚洲aⅴ| 亚洲人成网站999久久久综合| 欧美午夜剧场| 久久综合狠狠综合久久综合88| 亚洲日本电影| 老色批av在线精品| 亚洲午夜成aⅴ人片| 亚洲国产精品成人| 国产精品卡一卡二| 欧美福利视频网站| 欧美一级黄色录像| 一卡二卡3卡四卡高清精品视频| 狂野欧美激情性xxxx欧美| 亚洲一区二区毛片| 亚洲国产成人久久综合| 国产精品视区| 欧美日韩视频在线一区二区观看视频| 欧美一区二区大片| 亚洲无限乱码一二三四麻| 欧美激情一区二区三区不卡| 久久国产一二区| 亚洲午夜视频在线| 亚洲精品综合精品自拍| 国语自产精品视频在线看| 国产精品v欧美精品∨日韩| 欧美11—12娇小xxxx| 欧美一区二区三区在线播放| 制服丝袜亚洲播放| 日韩一级黄色av| 亚洲国产天堂久久综合网| 久久综合九色九九| 久久九九国产精品| 欧美一区二区三区免费视| 亚洲天堂久久| 99精品欧美一区二区三区综合在线| 黄色成人av在线| 国产亚洲欧美色| 国产亚洲午夜高清国产拍精品| 国产精品久久久久久久一区探花 | 久久免费国产精品1| 欧美在现视频| 欧美主播一区二区三区| 午夜精品免费| 欧美亚洲尤物久久| 欧美一区二区三区婷婷月色 | 亚洲日韩中文字幕在线播放| 亚洲国产精品va在线观看黑人| 激情婷婷欧美| 伊人成人网在线看| 1024国产精品| 亚洲精品久久久久久久久久久久久 | 亚洲精品一区在线观看| 亚洲人成毛片在线播放女女| 亚洲国产成人精品女人久久久 | 久热国产精品视频| 免费的成人av| 欧美激情精品久久久久| 亚洲电影激情视频网站| 亚洲国产精品久久久久婷婷老年| 亚洲国产精品一区二区第一页| 亚洲欧洲精品一区二区精品久久久| 亚洲人成毛片在线播放| 99视频一区二区| 亚洲综合电影一区二区三区| 香蕉成人啪国产精品视频综合网| 欧美在线日韩| 噜噜噜久久亚洲精品国产品小说| 欧美成人乱码一区二区三区| 欧美日韩国产一区精品一区| 国产精品www色诱视频| 国产嫩草影院久久久久| 精品福利电影| 日韩视频在线永久播放| 亚洲在线网站| 老司机免费视频一区二区| 亚洲黄色毛片| 亚洲主播在线观看| 久久综合给合久久狠狠狠97色69| 欧美另类高清视频在线| 国产精品永久免费视频| 亚洲成人在线网站| 亚洲欧美日韩国产综合在线 | 亚洲一区二区三区在线看| 欧美一区二区三区精品电影| 欧美成va人片在线观看| 夜夜精品视频一区二区| 久久久91精品国产| 欧美日韩中国免费专区在线看| 国产欧美一区二区精品婷婷| 亚洲精品久久久久| 久久精品理论片| 99精品视频免费观看| 久久蜜桃av一区精品变态类天堂| 欧美日韩免费一区二区三区| 一区二区三区亚洲| 午夜精品视频| 亚洲激情第一页| 久久久久久一区| 国产精品视频一二三| 日韩视频一区二区三区| 久久伊人亚洲| 亚洲综合三区| 欧美日韩在线观看视频| 亚洲狠狠婷婷| 免费中文日韩| 久久精品亚洲乱码伦伦中文 | 韩国三级电影一区二区| 亚洲欧美bt|