層序遍歷樹的節點,佇列實現
#include <iostream>
#include<bits/stdc++.h>
using namespace std;
typedef struct node{//樹節點定義
int data;
struct node *lchild,*rchild;
}treenode;
typedef struct{
treenode que[100];
int front,rear;
}myque;//佇列用來裝樹的節點函式
void init(myque &m){//初始化佇列函式
m.front=m.rear=0;
}
void enterqu(myque &m,treenode n){//入隊
m.que[m.rear]=n;
m.rear=(m.rear+1)%100;
}
void dequ(myque &m){//出隊
m.front=(m.front+1)%100;
}
treenode get(myque m){//得到佇列首元素
return m.que[m.front];
}
void f(myque m,treenode root){//層序遍歷樹的函式
treenode p;
enterqu(m,root);
while(m.front!=m.rear){
p=get(m);
dequ(m);
cout<<p.data<<" ";
if(p.lchild!=NULL) enterqu(m,*p.lchild);
if(p.rchild!=NULL) enterqu(m,*p.rchild);
}
}
int main()
{
myque m;
treenode *root,*a,*b,*c;
root=new treenode;
root->lchild=NULL;
root->rchild=NULL;
a=new treenode;
a->lchild=NULL;
a->rchild=NULL;
b=new treenode;
b->lchild=NULL;
b->rchild=NULL;
c=new treenode;
c->lchild=NULL;
c->rchild=NULL;
root->data=1;
a->data=2;
b->data=3;
c->data=4;
root->lchild=a;
root->rchild=b;
a->lchild=c;
init(m);
f(m,*root);
return 0;
}
相關文章
- 二叉樹的層序遍歷二叉樹
- leetcode----給定一個二叉樹,返回該二叉樹由底層到頂層的層序遍歷,(從左向右,從葉子節點到根節點,一層一層的遍歷)LeetCode二叉樹
- 遞迴和迭代實現二叉樹先序、中序、後序和層序遍歷遞迴二叉樹
- L2_006樹的遍歷(後序+中序->前序/層序)
- LeetCode102.二叉樹的層序遍歷LeetCode二叉樹
- 樹的層次遍歷
- 二叉樹的四種遍歷方法:先序,中序,後序,層序二叉樹
- 刷題系列 - 中序和後序遍歷佇列,構造對應二叉樹;佇列二叉樹
- LeetCode-107-二叉樹的層序遍歷 IILeetCode二叉樹
- 非遞迴實現先序遍歷和中序遍歷遞迴
- 144. 二叉樹的遍歷「前序、中序、後序」 Golang實現二叉樹Golang
- python-二叉樹:前、中、後、層序遍歷Python二叉樹
- 演算法 -- 實現二叉樹先序,中序和後序遍歷演算法二叉樹
- 144.二叉樹的前序遍歷145.二叉樹的後序遍歷 94.二叉樹的中序遍歷二叉樹
- 力扣#94 樹的中序遍歷力扣
- 【C++】返回每一層二叉樹的平均值(層序遍歷)C++二叉樹
- java實現二叉樹的Node節點定義手撕8種遍歷(一遍過)Java二叉樹
- 二叉樹的遍歷實現二叉樹
- jquery遍歷節點jQuery
- 二叉樹--後序遍歷二叉樹
- Leetcode 演算法題解系列 - 二叉樹的層序遍歷LeetCode演算法二叉樹
- 刷題系列 - 給出前序和後序遍歷佇列,構造對應二叉樹佇列二叉樹
- 二叉樹的按層遍歷二叉樹
- 二叉樹:構造二叉樹(通過前序和中序遍歷)、映象翻轉、層次遍歷二叉樹
- [資料結構] BFS演算法實現層序遍歷輸出一顆二叉樹資料結構演算法二叉樹
- 刷題系列 - Python實現二叉樹按層級遍歷Python二叉樹
- 刷題筆記:樹的前序、中序、後序遍歷筆記
- leetcode 103. 二叉樹的鋸齒形層序遍歷 BFS方法LeetCode二叉樹
- 佇列 優先順序佇列 python 程式碼實現佇列Python
- Java中用遞迴和迭代實現二叉樹的中序( InOrder )遍歷Java遞迴二叉樹
- 【資料結構】佇列(順序佇列、鏈佇列)的JAVA程式碼實現資料結構佇列Java
- 二分搜尋樹系列之[ 深度優先-層序遍歷 (ergodic) ]Go
- 二分搜尋樹系列之「深度優先-層序遍歷 (ergodic) 」Go
- 二叉樹的先中後序遍歷二叉樹
- 二叉樹的先,中,後序遍歷二叉樹
- 二叉樹的前中後序遍歷二叉樹
- 106. 從中序與後序遍歷序列構造二叉樹——Java實現二叉樹Java
- 根據二叉樹的前序遍歷和中序遍歷輸出二叉樹;二叉樹