1八、【常見算法】二叉樹的遍歷

二叉樹的遍歷

二叉樹的遍歷大體可分爲先序遍歷、中序遍歷、後序遍歷和層次遍歷四種。post

一、二叉樹的結構體

1 typedef struct BinTreeNode 
2 { 
3     int data; // 默認結點中存儲整型數據 
4     struct BinTreeNode* lchild; 
5     struct BinTreeNode* rchild; 
6 };

二、前序遍歷

遞歸方法:spa

 1 //前序遍歷-遞歸方法
 2 void preOrder(BinTreeNode *root)
 3 {
 4     if(root != NULL)
 5     {
 6         cout << root->data << " ";
 7         preOrder(root->lchild);
 8         preOrder(root->rchild);
 9     }
10 }

非遞歸方法:code

 1 //前序遍歷-非遞歸方法
 2 void preOrder(BinTreeNode *root)
 3 {
 4     stack<BinTreeNode *> s;
 5     BinTreeNode *p = root;
 6     while(p != NULL || !s.empty())
 7     {
 8 
 9         while( p!= NULL)
10         {
11             cout << p->data << " ";
12             s.push(p);
13             p = p->lchild;
14         }
15         if(!s.empty())
16         {
17             p = s.top();
18             s.pop();
19             p = p->rchild;
20         }
21     }
22 }

三、中序遍歷

遞歸方法:blog

 1 //中序遍歷 - 遞歸
 2 void inOrder(BinTreeNode *root)
 3 {
 4     if(root != NULL)
 5     {
 6         inOrder(root->lchild);
 7         cout << root->data << " ";
 8         inOrder(root->rchild);
 9     }
10 }

非遞歸方法:遞歸

 1 //中序遍歷 - 非遞歸
 2 void inOrder(BinTreeNode *root)
 3 {
 4     stack<BinTreeNode *> s;
 5     BinTreeNode *p;
 6     while(p != NULL || s.empty())
 7     {
 8         while(p != NULL)
 9         {
10             s.push(p);
11             p = p->lchild;
12         }
13         if(!s.empty())
14         {
15             p = s.top();
16             cout << p->data << " ";
17             s.pop();
18             p = p->rchild;
19         }
20     }
21 }

四、後序遍歷

遞歸方法class

 1 //後序遍歷 - 遞歸
 2 void postOrder(BinTreeNode *root)
 3 {
 4     if(root != NULL)
 5     {
 6         postOrder(root->lchild);
 7         postOrder(root->rchild);
 8         cout << root->data << " ";
 9     }
10 }

非遞歸方法二叉樹

 1 //後序遍歷 - 非遞歸
 2 void postOrder(BinTreeNode *root)
 3 {
 4     stack<BinTreeNode *> s;
 5     BinTreeNode *p = root, *r = NULL;
 6     while(p != NULL || !s.empty())
 7     {
 8         if(p)//走到最左邊
 9         {
10             s.push(p);
11             p = p->lchild;
12         }
13         else//向右
14         {
15             p = s.top();
16             if(p->rchild && p->rchild != r)//右子數存在且未被訪問
17             {
18                 p = p->rchild;
19                 s.push(p);
20                 p = p->lchild;
21             }
22             else//不然,彈出節點並訪問
23             {
24                 p = s.top();
25                 s.pop();
26                 cout << p->data << " ";
27                 r = p;
28                 p = NULL;
29             }
30         }
31     }
32 }

五、層次遍歷

非遞歸方法遍歷

 1 //層次遍歷 - 非遞歸
 2 void levelOrder(BinTreeNode *root)
 3 {
 4     queue<BinTreeNode *> q;
 5     BinTreeNode *p = root;
 6     q.push(p);
 7     while(!q.empty())
 8     {
 9         p = q.front();
10         cout << p->data << " ";
11         q.pop();
12         
13         if(p->lchild != NULL)
14         {
15             q.push(p->lchild);
16         }
17         
18         if(p->rchild != NULL)
19         {
20             q.push(p->rchild);
21         }
22     }
23 }
相關文章
相關標籤/搜索