亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁(yè) > 知識(shí)庫(kù) > 數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸

數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸

熱門(mén)標(biāo)簽:昆明電銷(xiāo)機(jī)器人價(jià)格 地圖標(biāo)注人員分布 益陽(yáng)400電話申請(qǐng)辦理流程 上海機(jī)器人外呼系統(tǒng)哪家好 江西全自動(dòng)外呼系統(tǒng)報(bào)價(jià) 400的電話一般從哪里辦理 春運(yùn)地圖標(biāo)注app 怎么用百度地圖標(biāo)注坐標(biāo) 梧州防封電銷(xiāo)卡

數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸

實(shí)例代碼:

#include iostream> 
#include queue> 
#include stack> 
#include assert.h> 
using namespace std; 
templateclass T> 
struct BinaryTreeNode 
{ 
  BinaryTreeNodeT>* _left; 
  BinaryTreeNodeT>* _right; 
  T _data; 
  BinaryTreeNode(const T x) 
    :_left(NULL) 
    , _right(NULL) 
    , _data(x) 
  {} 
    }; 
template class T> 
class BinaryTree 
{ 
  typedef BinaryTreeNodeT> Node; 
public: 
  BinaryTree() 
    :_root(NULL) 
  {} 
  BinaryTree(T* a, size_t n, const T invalid) 
  { 
    size_t index = 0; 
     _root=CreateTree(a, n, invalid, index); 
  } 
  BinaryTree(const BinaryTreeT> t) 
  {  
    _root = _Copy(t._root); 
  } 
  BinaryTreeT> operator=( BinaryTreeT> t) 
  { 
    swap(_root,t._root); 
    return *this; 
  } 
  ~BinaryTree() 
  { 
      _DestroyTree(_root); 
  } 
  Node* CreateTree(const T* a, size_t n, const T invalid, size_t index) 
  { 
    assert(a); 
    Node* root = NULL; 
    if (index  n  a[index] != invalid) 
    { 
      root = new Node(a[index]); 
      root->_left = CreateTree(a, n, invalid, ++index); 
      root->_right = CreateTree(a, n, invalid, ++index); 
    } 
    return root; 
  } 

 先序遍歷(遞歸法)  

 void PrevOrder() 
  { 
    _PrevOrder(_root); 
    cout  endl; 
  } 
  //先序遍歷非遞歸 
  void PrevOrderNorR( ) 
  { 
    Node* cur = _root; 
    stack Node* >s; 
    while (cur||!s.empty()) 
    { 
      while (cur) 
      { 
        cout  cur->_data  " "; 
        s.push(cur); 
        cur = cur->_left; 
      } 
      Node* top = s.top(); 
      s.pop(); 
      cur = top->_right; 
    } 
    cout  endl; 
  } 

后序遍歷     

 void PostOrder() 
  { 
    _PostOrder(_root); 
    cout  endl; 
  } 
  //后序遍歷非遞歸 
  void PostOrderNorR() 
  {  
      Node* cur = _root; 
      Node* prev = NULL; 
      stack Node* >s; 
      while (cur || !s.empty()) 
      { 
        while (cur) 
        { 
          s.push(cur); 
          cur = cur->_left; 
        } 
        Node* top = s.top(); 
        if (NULL==top->_right  prev==top->_right) 
        { 
          cout  top->_data  " "; 
           s.pop(); 
           prev = top; 
        } 
        cur = top->_right; 
      } 
      cout  endl; 
  } 
 
  //中序遍歷 
  void InOrder() 
  { 
    _InOrder(_root); 
    cout  endl; 
  } 
  //中序遍歷非遞歸 
  void InOrderNorR() 
  { 
    Node* cur = _root; 
    stack Node* >s; 
    while (cur || !s.empty()) 
    { 
      while (cur) 
      { 
        s.push(cur); 
        cur = cur->_left; 
      } 
      Node* top = s.top(); 
      s.pop(); 
      cout  top->_data  " "; 
      cur = top->_right; 
    } 
    cout  endl; 
  } 
 
  //節(jié)點(diǎn)個(gè)數(shù) 
  size_t Size() 
  { 
    return _Size(_root); 
  } 
  //葉子節(jié)點(diǎn)個(gè)數(shù) 
  size_t LeafSize() 
  { 
    return _LeafSize(_root); 
  } 
  //樹(shù)的深度 
  size_t Depth() 
  { 
    return _Depth(_root); 
  }  
  size_t GetKLevel(size_t k) 
  { 
    return _GetKLevel(_root,k); 
  } 
  // 查找 
  Node* Find(size_t x) 
  { 
    return _Find(_root,x); 
  } 
  //層序遍歷 
  void LevelOrder() 
  { 
    queueNode*> q; 
    if (_root) 
    { 
      q.push(_root); 
    } 
    while (!q.empty()) 
    { 
      Node* front = q.front(); 
      cout  front->_data  " "; 
      q.pop(); 
      if (front->_left) 
      { 
        q.push(front->_left); 
      } 
      if (front->_right) 
      { 
        q.push(front->_right); 
      } 
    } 
    cout  endl; 
  } 
   
protected: 
  Node* _Copy(Node* root) 
  { 
    if (root==NULL) 
    { 
      return NULL; 
    } 
    Node* NewRoot = new Node(root->_data); 
    NewRoot->_left = _Copy(root->_left); 
    NewRoot->_right = _Copy(root->_right); 
    return NewRoot; 
  } 
  void _DestroyTree(Node* root) 
  { 
    if (NULL==root) 
    { 
      return; 
    } 
   _DestroyTree(root->_left); 
   _DestroyTree(root->_right); 
   delete root; 
  } 
  void _PrevOrder(BinaryTreeNodeT>* root) 
  { 
    if (root) 
    { 
      cout  root->_data  " ";  
      _PrevOrder(root->_left); 
      _PrevOrder(root->_right); 
    }   
  } 
  void _PostOrder(BinaryTreeNodeT>* root) 
  { 
    if (root) 
    { 
      _PostOrder(root->_left); 
      _PostOrder(root->_right); 
      cout  root->_data  " "; 
    } 
  } 
  void _InOrder(BinaryTreeNodeT>* root) 
  { 
    if (root) 
    { 
      _InOrder(root->_left); 
      cout  root->_data  " "; 
      _InOrder(root->_right); 
       
    } 
  } 
  int _Size(BinaryTreeNodeT>* root) 
  { 
   if (root==0) 
   { 
     return 0; 
   } 
   return _Size(root->_left) + _Size(root->_right) + 1; 
  } 
  int _LeafSize(BinaryTreeNodeT>* root) 
  { 
    if (root==NULL) 
    { 
    return 0; 
    } 
    else if (root->_left == NULLroot->_right == NULL) 
    { 
      return 1; 
    } 
    return _LeafSize(root->_left) + _LeafSize(root->_right); 
  } 
  int _Depth(Node* root) 
  { 
    if (root==NULL) 
    { 
      return 0; 
    } 
    int left = _Depth(root->_left); 
    int right = _Depth(root->_right); 
    return left > right ? left + 1 : right + 1; 
  } 
 
 
  int _GetKLevel(Node* root, size_t k) 
  { 
    assert(k>0); 
    if (root==NULL) 
    { 
      return 0; 
    } 
    else if (k==1) 
    { 
      return 1; 
    } 
    return _GetKLevel(root->_left, k - 1) + _GetKLevel(root->_right, k - 1); 
  } 
  Node* _Find(Node* root, const T x) 
  { 
    if (root==NULL) 
    { 
      return NULL; 
    } 
    if (root->_data==x) 
    { 
      return root; 
    } 
    Node* ret = _Find(root->_left,x); 
    if (ret != NULL) 
      return ret; 
    return _Find(root->_right, x); 
  } 
 
  private: 
  BinaryTreeNodeT>* _root; 
}; 
 
 
 
void TestBinaryTree() 
{ 
  int array[10] = { 1, 2, 3, '#', '#', 4, '#', '#', 5, 6 }; 
  BinaryTreeint> t1(array,sizeof(array)/sizeof(array[0]),'#'); 
  BinaryTreeint>t2(t1); 
  BinaryTreeint> t3; 
  t3 = t2; 
  t2.LevelOrder(); 
  t3.LevelOrder(); 
  t1.LevelOrder(); 
  t1.PrevOrder(); 
  t1.PrevOrderNorR(); 
  t1.InOrder(); 
  t1.InOrderNorR(); 
  t1.PostOrder(); 
  t1.PostOrderNorR(); 
  cout  endl; 
  cout  t1.Size()  endl; 
  cout  t1.LeafSize()  endl; 
  cout  t1.Depth()  endl; 
 
  cout  t1.GetKLevel(2)  endl; 
  cout  t1.Find(2)  endl; 
} 

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

您可能感興趣的文章:
  • C++ 數(shù)據(jù)結(jié)構(gòu)二叉樹(shù)(前序/中序/后序遞歸、非遞歸遍歷)
  • C++使用遞歸和非遞歸算法實(shí)現(xiàn)的二叉樹(shù)葉子節(jié)點(diǎn)個(gè)數(shù)計(jì)算方法
  • C++基于遞歸和非遞歸算法判定兩個(gè)二叉樹(shù)結(jié)構(gòu)是否完全相同(結(jié)構(gòu)和數(shù)據(jù)都相同)
  • C++基于遞歸和非遞歸算法求二叉樹(shù)鏡像的方法
  • C++非遞歸隊(duì)列實(shí)現(xiàn)二叉樹(shù)的廣度優(yōu)先遍歷
  • C++非遞歸建立二叉樹(shù)實(shí)例
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之二叉樹(shù)的非遞歸后序遍歷算法

標(biāo)簽:惠州 贛州 河南 北京 亳州 新疆 九江 懷化

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸》,本文關(guān)鍵詞  數(shù)據(jù)結(jié)構(gòu),二叉,樹(shù),的,遞歸,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于數(shù)據(jù)結(jié)構(gòu) 二叉樹(shù)的遞歸與非遞歸的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    99色吧| 天天色色色| 欧美a免费| 国产一区二区精品久| 欧美激情一区二区三区中文字幕| 精品视频免费在线| 国产91精品系列在线观看| 99色视频在线| 黄色免费三级| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产一级生活片| 久久99中文字幕| 日韩专区一区| 国产网站免费| 亚洲精品影院久久久久久| 欧美激情一区二区三区在线| 九九热精品免费观看| 二级片在线观看| 日韩在线观看视频免费| 国产不卡在线观看| 麻豆系列国产剧在线观看| 成人高清视频在线观看| 国产91视频网| 91麻豆精品国产高清在线| 欧美激情伊人| 韩国妈妈的朋友在线播放| 国产麻豆精品hdvideoss| 在线观看导航| 麻豆网站在线免费观看| 超级乱淫黄漫画免费| 99久久精品国产片| 精品国产一区二区三区久久久狼| 亚欧成人乱码一区二区| 成人免费观看视频| 色综合久久天天综合绕观看| 韩国毛片免费| a级黄色毛片免费播放视频| 青青久热| 成人a大片高清在线观看| 韩国妈妈的朋友在线播放| 午夜欧美福利| 久草免费在线视频| 高清一级做a爱过程不卡视频| 欧美一区二区三区在线观看| 国产一区二区精品| 天堂网中文字幕| 亚洲 国产精品 日韩| 国产91视频网| 九九精品在线播放| a级毛片免费观看网站| 日韩欧美一二三区| 一级毛片视频在线观看| 日韩在线观看免费| 成人免费一级纶理片| 日韩一级精品视频在线观看| 国产亚洲精品成人a在线| 韩国三级香港三级日本三级| 成人在免费观看视频国产| 黄视频网站免费观看| 成人高清视频免费观看| 黄视频网站免费| 精品在线视频播放| 99热精品一区| 国产一区二区福利久久| 国产麻豆精品视频| 国产一级生活片| 美国一区二区三区| 日韩av东京社区男人的天堂| 欧美另类videosbestsex久久| 亚洲第一页乱| 99久久精品国产免费| 精品国产一区二区三区免费| 二级片在线观看| 一级片片| 99热精品一区| 欧美大片aaaa一级毛片| 国产一区二区精品久久91| 欧美另类videosbestsex视频| 久久精品欧美一区二区| 日韩免费在线视频| 日韩男人天堂| 精品在线观看一区| 中文字幕Aⅴ资源网| 免费国产在线观看| 九九热精品免费观看| a级黄色毛片免费播放视频| 97视频免费在线| 精品国产亚洲一区二区三区| 国产精品免费久久| 久久久久久久男人的天堂| 国产高清在线精品一区a| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 午夜欧美福利| 日韩av片免费播放| 色综合久久天天综合绕观看| 九九久久国产精品| 精品视频在线观看视频免费视频| 91麻豆国产级在线| 国产一区二区福利久久| 日日日夜夜操| 日本免费看视频| 国产激情视频在线观看| 韩国三级视频网站| 欧美18性精品| 91麻豆精品国产高清在线| 天天做日日爱| 超级乱淫黄漫画免费| 国产高清在线精品一区二区 | 亚洲 男人 天堂| 日韩在线观看视频免费| 亚欧成人毛片一区二区三区四区| 美女免费黄网站| 国产原创视频在线| 91麻豆国产级在线| 国产精品自拍在线观看| 91麻豆精品国产自产在线观看一区 | 精品视频免费看| 精品国产三级a∨在线观看| 日韩专区亚洲综合久久| 欧美1卡一卡二卡三新区| 亚欧乱色一区二区三区| 精品视频免费看| 精品国产三级a∨在线观看| 日本免费看视频| 成人高清视频在线观看| 天天做人人爱夜夜爽2020毛片| 台湾美女古装一级毛片| a级精品九九九大片免费看| 青青久久精品| 一级片片| 精品在线观看一区| 精品视频在线观看视频免费视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情一区二区三区在线播放| 日本伦理网站| 欧美a免费| 欧美爱爱动态| 黄色免费三级| 青草国产在线| 亚洲第一视频在线播放| 青青久久精品| 一级毛片视频在线观看| 美女免费精品视频在线观看| 欧美日本韩国| 亚洲www美色| 日韩中文字幕一区二区不卡| 韩国三级香港三级日本三级la| 日日日夜夜操| 亚欧成人毛片一区二区三区四区| 韩国三级香港三级日本三级| 国产精品1024永久免费视频| 午夜家庭影院| 精品视频在线看 | 免费国产在线观看| 成人免费高清视频| 精品国产一区二区三区久久久蜜臀| 国产一级生活片| 欧美国产日韩一区二区三区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产不卡福利| 日韩中文字幕在线亚洲一区| 久久精品免视看国产明星| 国产一区二区精品在线观看| 一级女性全黄生活片免费| 台湾毛片| 免费国产在线视频| 国产网站在线| 国产成人啪精品| 日韩avdvd| 精品视频在线观看一区二区| 精品国产一区二区三区久久久蜜臀| 日本特黄特黄aaaaa大片| 国产成人女人在线视频观看| 91麻豆精品国产片在线观看| 日韩在线观看免费| 免费毛片播放| 日韩女人做爰大片| 91麻豆精品国产高清在线| 青青青草影院| 日韩中文字幕在线观看视频| 国产视频久久久久| 国产一级生活片| 国产一区精品| 久久国产影视免费精品| 美女免费毛片| 日韩中文字幕一区| 欧美大片一区| 99热热久久| 国产激情视频在线观看| 成人高清免费| 亚洲精品久久玖玖玖玖| 日韩欧美一及在线播放| 欧美激情在线精品video| 99热热久久| 日韩在线观看免费完整版视频| 99久久精品费精品国产一区二区| 成人高清护士在线播放| 成人免费观看男女羞羞视频| 精品国产亚洲人成在线|