二叉樹遍歷 (前序 層次 == 深度 廣度) 層次遍歷

#include<iostream>
#include<cstdlib>
#include<queue>
#include<stack>
using namespace std;
struct Node;

//二叉樹節點 
class Node{
    public:
        Node(int node):parent(NULL),left(NULL),right(NULL),data(node){}
    //private:
        int data;
        Node* parent; 
        Node* left;
        Node* right;
};
//二叉樹 
struct binaryTree{
    Node* root;
    binaryTree():root(NULL){}
    void insert(int a);
};

//二叉樹插入 
void binaryTree::insert(int a)
{
    Node* temp = new Node(a);
    if(NULL == root)
    {
        root = temp;
        temp->parent = root;
        return;
    }
    Node *y, *tempRoot = root;
    while(NULL != tempRoot)
    {
        y = tempRoot;
        if(tempRoot->data < a)
            tempRoot = tempRoot->right;
        else
            tempRoot = tempRoot->left;
    }
    if(y->data < a)
        y->right = temp;
    else
        y->left = temp;
        
    temp->parent = y;
}
//前序遍歷
void preOrder(Node *root)
{
    Node* temp = root;
    if(temp)
        cout << temp->data << endl;
    if(temp->left)
        preOrder(temp->left);
    if(temp->right)
        preOrder(temp->right);
} 


//中序遍歷 
void inorder(Node* root)
{
    Node* temp = root;
    if(temp->left)
        inorder(temp->left);
    cout << temp->data << endl;
    if(temp->right)
        inorder(temp->right);    
}

//層次遍歷 
void layerOrder(Node *root)
{
    //Node *temp = root;
    queue<Node*> qu;
    if(root)
        qu.push(root);
    else
        return;
    while(!qu.empty())
    {
        Node* temp = qu.front();
        if(temp->left)
            qu.push(temp->left);
        if(temp->right)
            qu.push(temp->right);
        cout << temp->data << endl;
        qu.pop();
    }
}

//深度優先遍歷

void DPF(Node *root)
{
    stack<Node*> st;
    if(root)
        st.push(root);
    else
        return;
    while(!st.empty())
    {
        Node *temp = st.top();
        st.pop();
        if(temp->right)
            st.push(temp->right);
        if(temp->left)
            st.push(temp->left);
        cout << temp->data << endl;
            
    }
}

//廣度優先遍歷 

void BDF(Node *root)
{
    
}

int main()
{
    int n = 10;
    binaryTree bTree;
    while(--n)
        {
            int t = rand()%100;
        cout << t << endl;
        bTree.insert(t);
    }
    cout << endl;
    cout << "開始: " <<endl; 
    inorder(bTree.root);
    
    cout << "-----------------" << endl;
    layerOrder(bTree.root);
    cout << "++++++++++++++++++++" << endl;
    cout << "前序遍歷:" << endl; 
    preOrder(bTree.root);
    cout << "*********************" << endl;
    cout << "深度優先遍歷: " << endl; 
    DPF(bTree.root);
    return 0;
}
相關文章
相關標籤/搜索