欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C語言

當(dāng)前位置:主頁 > 軟件編程 > C語言 >

C語言 數(shù)據(jù)結(jié)構(gòu)之中序二叉樹實例詳解

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊: 次

C語言數(shù)據(jù)結(jié)構(gòu) 中序二叉樹

前言:

線索二叉樹主要是為了解決查找結(jié)點的線性前驅(qū)與后繼不方便的難題。它只增加了兩個標(biāo)志性域,就可以充分利用沒有左或右孩子的結(jié)點的左右孩子的存儲空間來存放該結(jié)點的線性前驅(qū)結(jié)點與線性后繼結(jié)點。兩個標(biāo)志性域所占用的空間是極少的,所有充分利用了二叉鏈表中空閑存的儲空間。

   要實現(xiàn)線索二叉樹,就必須定義二叉鏈表結(jié)點數(shù)據(jù)結(jié)構(gòu)如下(定義請看代碼):

left

leftTag

data

rightTag

right

說明:

1.       leftTag=false時,表示left指向該結(jié)點的左孩子;

2.       leftTag=true時,表示left指向該結(jié)點的線性前驅(qū)結(jié)點;

3.       rightTag=false時,表示right指向該結(jié)點的右孩子;

4.       rightTag=true時,表示right指向該結(jié)點的線性后繼結(jié)點;

     以二叉鏈表結(jié)點數(shù)據(jù)結(jié)構(gòu)所構(gòu)成的二叉鏈表作為二叉樹的存儲結(jié)構(gòu),叫做線索二叉鏈表;指向結(jié)點的線性前驅(qū)或者線性后繼結(jié)點的指針叫做線索;加上線索的二叉樹稱為線索二叉樹;對二叉樹以某種次序遍歷將其變?yōu)榫€索二叉樹的過程叫做線索化。

中序次序線索化二叉樹算法:

  中序次序線索化是指用二叉鏈表結(jié)點數(shù)據(jù)結(jié)構(gòu)建立二叉樹的二叉鏈表,然后按照中序遍歷的方法訪問結(jié)點時建立線索;(具體看代碼)

檢索中序二叉樹某結(jié)點的線性前驅(qū)結(jié)點的算法:

1.       如果該結(jié)點的leftTag=true,那么left就是它的線性前驅(qū);

2.       如果該結(jié)點的leftTag=false,那么該結(jié)點左子樹最右邊的尾結(jié)點就是它的線性前驅(qū)點;

(具體請看代碼)

檢索中序二叉樹某結(jié)點的線性后繼結(jié)點和算法:

1.       如果該結(jié)點的right=true,那么right就是它的線性后繼結(jié)點;

2.       如果該結(jié)點的right=false,那么該結(jié)點右子樹最左邊的尾結(jié)點就是它的線性后繼結(jié)點

(具體請看代碼)


圖:后繼線索


圖:前驅(qū)線索

 節(jié)點定義:

struct Node 
{ 
  int data; 
  bool leftTag; 
  bool rightTag; 
  Node* left; 
  Node* right; 
  Node(int _data):data(_data),left(0),right(0),leftTag(false),rightTag(false){} 
}; 

類定義:

class BinaryTree 
{ 
private: 
  Node* root; 
private: 
  Node* head; 
  Node* pre; 
  void makeThread(Node* node); 
public: 
  void buildThread(); 
  void traverseBySuccessor(); 
  void traverseByPredecessor(); 
 
// helper methods 
private: 
  static inline bool visit(Node* T) 
  { 
    if (T) 
    { 
      printf("data:%c, left:%c, right:%c\n", 
        (char)T->data, 
        (T->left!=0) ? (char)T->left->data : '#', 
        (T->right!=0) ? (char)T->right->data : '#'); 
      return true; 
    } 
    else return false; 
  } 
}; 

方法定義:

void BinaryTree::makeThread(Node* node) 
{ 
  if (node!=NULL) 
  { 
    makeThread(node->left); 
    if (pre!= NULL) 
    { 
      if (pre->right==NULL) // 如果前驅(qū)節(jié)點的右子樹為空, 那么把前驅(qū)節(jié)點的右子樹用作線索 
      { 
        pre->rightTag = true;  
        pre->right = node; 
      } 
      else pre->rightTag = false; 
    } 
    if (node->left==NULL) // 如果當(dāng)前結(jié)點的左子樹為空, 那么把當(dāng)前結(jié)點的左子樹用作線索 
    { 
      node->leftTag = true; 
      node->left = pre; 
    } 
    else node->leftTag = false; 
    pre = node; 
    makeThread(node->right); 
  } 
} 
 
void BinaryTree::traverseBySuccessor() 
{ 
  Node* p = head->left; //first find the root node 
  // 親測表明 如果不使用head啞節(jié)點 就要設(shè)三道卡, 防止p訪問到NULL,  
  // 分別在主while處, 第二個visit處和下面的p=p->right處 
  while (p!=head) 
  { 
    while (!p->leftTag) 
      p = p->left; 
    visit(p); 
 
    while (p->rightTag && p->right!=head) 
    { 
      p = p->right; 
      visit(p); 
    } 
    p = p->right; 
  } 
  cout<<endl; 
} 
 
void BinaryTree::traverseByPredecessor() 
{ 
  Node* p = head->left; //first find the root node 
  while (p!=head) 
  { 
    while (!p->rightTag) 
      p = p->right; 
    visit(p); 
    if (p!=NULL) 
    { 
      while (p->leftTag && p->left!=head) 
      { 
        p = p->left; 
        visit(p); 
      } 
      p = p->left; 
    } 
  } 
  cout<<endl; 
} 
 
void BinaryTree::buildThread() 
{ 
  pre = NULL; 
  head = new Node('@'); 
  head->left = root; 
  head->right = head; 
  makeThread(root); 
  // 經(jīng)過了makeThread過程之后, pre必然指向中序遍歷最晚的結(jié)點. 
  // 把pre的右子樹指向head, 就構(gòu)成了一個雙向循環(huán)鏈表 
  // 
  pre->rightTag = 1; 
  pre->right = head; 
  pre = NULL; 
  Node* p = root; 
  /* 
   * 在建立前驅(qū)線索的時候,最左邊的結(jié)點沒有和head結(jié)點連接。要在這里補上 
   */ 
  while (p->left!=NULL) 
    p = p->left; 
  p->left = head; 
} 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有