#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; }