nodestack

二叉树深度优先遍历和广度优先遍历

大城市里の小女人 提交于 2020-11-12 09:01:37
  对于一颗二叉树,深度优先搜索(Depth First Search)是沿着树的深度遍历树的节点,尽可能深的搜索树的分支。以上面二叉树为例,深度优先搜索的顺序 为:ABDECFG。怎么实现这个顺序呢 ?深度优先搜索二叉树是先访问根结点,然后遍历左子树接着是遍历右子树,因此我们可以利用堆栈的先进后出的特点, 现将右子树压栈,再将左子树压栈,这样左子树就位于栈顶,可以保证结点的左子树先与右子树被遍历。   广度优先搜索(Breadth First Search),又叫宽度优先搜索或横向优先搜索,是从根结点开始沿着树的宽度搜索遍历,上面二叉树的遍历顺序为:ABCDEFG. 可以利用队列实现广度优先搜索。   下面给出二叉树dfs和bfs的具体代码: #include <vector> #include <iostream> #include <stack> #include <queue> using namespace std; struct BitNode { int data; BitNode *left, *right; BitNode(int x) :data(x), left(0), right(0){} }; void Create(BitNode *&root) { int key; cin >> key; if (key == -1) root = NULL;

二叉树创建 以及深度优先遍历和广度优先遍历

爷,独闯天下 提交于 2020-11-12 09:01:23
对于一颗二叉树,深度优先搜索(Depth First Search)是沿着树的深度遍历树的节点,尽可能深的搜索树的分支。以上面二叉树为例,深度优先搜索的顺序 为:ABDECFG。怎么实现这个顺序呢 ?深度优先搜索二叉树是先访问根结点,然后遍历左子树接着是遍历右子树,因此我们可以利用堆栈的先进后出的特点, 现将右子树压栈,再将左子树压栈,这样左子树就位于栈顶,可以保证结点的左子树先与右子树被遍历。   广度优先搜索(Breadth First Search),又叫宽度优先搜索或横向优先搜索,是从根结点开始沿着树的宽度搜索遍历,上面二叉树的遍历顺序为:ABCDEFG. 可以利用队列实现广度优先搜索。   下面给出二叉树dfs和bfs的具体代码: 1 #include <vector> 2 #include <iostream> 3 #include <stack> 4 #include <queue> 5 using namespace std; 6 7 struct BitNode 8 { 9 int data; 10 BitNode *left, * right; 11 BitNode( int x) :data(x), left( 0 ), right( 0 ){} 12 }; 13 14 void Create(BitNode *& root) 15 { 16 int key;

【数据结构】二叉树的创建、遍历以及广度深度优先搜索的实现

喜欢而已 提交于 2020-11-12 08:29:29
先序、中序、后序遍历主要依靠递归来实现 广度优先搜索主要依靠队列(先进先出),深度优先依靠栈(先进后出) #include<iostream> using namespace std; template < class T> struct Node { T data; Node <T> * next; }; template < class T> class LinkStack { private : Node <T> * top; public : LinkStack(); ~ LinkStack(); void Push(T x); T Pop(); T Top(); bool Empty(); }; template < class T> LinkStack <T> ::LinkStack() { top = NULL; } template < class T> LinkStack <T>::~ LinkStack() { Node <T> *p = top; while (p) { Node <T> *q = p; p = p-> next; delete q; } top = NULL; } template < class T> void LinkStack<T> ::Push(T x) { Node <T> *s = new Node<T> (); s ->data