亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

c++二叉樹的幾種遍歷算法

2020-01-26 16:22:08
字體:
來源:轉載
供稿:網友

1. 前序/中序/后序遍歷(遞歸實現)

復制代碼 代碼如下:

// 前序遍歷
void BT_PreOrder(BiTreePtr pNode){
if (!pNode)  return;   
visit(pNode);  
BT_PreOrder(pNode->left);
BT_PreOrder(pNode->right);   }
// 中序遍歷
void BT_PreOrder(BiTreePtr pNode){ 
if (!pNode)  return;    
BT_PreOrder(pNode->left);  
visit(pNode);  
BT_PreOrder(pNode->right);}
// 后序遍歷void BT_PreOrder(BiTreePtr pNode){   
if (!pNode)  return;      
BT_PreOrder(pNode->left);  
BT_PreOrder(pNode->right);   
visit(pNode);}

2. 前序遍歷(非遞歸實現)
復制代碼 代碼如下:

// 用棧實現
void BT_PreOrderNoRec1(BiTreePtr pNode){
stack<BiTreePtr> s;
while (!pNode || !s.empty()) 
{      
if (!pNode) 
{           
visit(pNode);   
s.push(pNode);       
pNode = pNode->left;  
}      
else      
{          
pNode = s.pop();
pNode = pNode->right;    

}
}
// 用棧實現
void BT_PreOrderNoRec2(BiTreePtr pNode){
if (!pNode)  
{      
stack<BiTreePtr> s; 
s.push(pNode);     
while (!s.empty())  
{          
BiTreePtr pvNode = s.pop();
visit(pvNode);         
s.push(pvNode->right);      
s.push(pvNode->left);  
}  
}}
//
不用棧實現 每個節點含父節點指針和isVisited【默認為false】狀態變量 且該二叉樹含一個頭節點
void BT_PreOrderNoRec3(BiTreePtr pNode){   
while (!pNode)
// 回溯到指向根節點的頭節點時退出 
{       
if( !pNode->bVisited )
// 判定是否已被訪問   
{             
visit(pNode);   
pNode->isVisited = true;  
}       
if ( pNode->left && !pNode->left->isVisited )    
pNode = pNode->left;     
else if( pNode->right && !pNode->right->isVisited ) 
pNode = pNode->right;      
else  
//回溯    
pNode = pNode->parent; 
}}

3. 中序遍歷(非遞歸實現)

復制代碼 代碼如下:

// 用棧實現
void BT_InOrderNoRec1(BiTreePtr pNode){
stack<BiTreePtr> s;
while (!pNode || !s.empty())  
{      
if (!pNode)      
{         
s.push(pNode);      
pNode = pNode->left;   
}  
else  
{       
pNode = s.pop(); 
visit(pNode);      
pNode = pNode->right;

}}
// 不用棧實現 每個節點含父節點指針和isVisited【默認為false】的狀態變量 且該二叉樹含一個頭節點
void BT_InOrderNoRec2(BiTreePtr pNode){   
while (!pNode)
// 回溯到指向根節點的頭節點時退出
{     
while (pNode->left && !pNode->left->isVisited)      
pNode = pNode->left;     
if (!pNode->isVisited)      
{         
visit(pNode);   
pNode->isVisited=true;  
}     
if (pNode->right && !pNode->right->isVisited) 
pNode = pNode->right;  
else         
pNode = pNode->parent;
}}

4. 后序遍歷(非遞歸實現)
復制代碼 代碼如下:

void BT_PostOrderNoRec(BiTreePtr pNode){
if(!pNode) return;
stack<BiTreePtr> s;
s.push(pNode); 
while (!s.empty())  
{    
BiTreePtr pvNode = s.pop(); 
if (pvNode->isPushed)
// 表示其左右子樹都已入棧,訪問該節點      
visit(pvNode);   
else    
{       
if (pvNode->right) 
{             
pvNode->right->isPushed = false;
S.push(pvNode->right);         
}          
if (pvNode->left)    
{              
pvNode->left->isPushed = false;  
s.push(pvNode->left);         
}         
pvNode->isPushed = true;     
s.push(pvNode);   
}  
}}

5. 層序遍歷(使用隊列)

復制代碼 代碼如下:

void BT_LevelOrder(BiTreePtr pNode){
if (!pNode) return;  
queue<BiTreePtr> q;  
q.push(pNode); 
BiTreePtr pvNode;
while (!q.empty())
{     
pvNode = q.pop();    
visit(pvNode);  
if (pvNode->left)
q.push(pvNode->left); 
if (pvNode->right)   
q.push(pvNode->right);  
}}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
最好看的2019的中文字幕视频| 国产精品视频播放| 国产一区二区丝袜| 日韩av资源在线播放| 国产成人精品综合久久久| 久久久天堂国产精品女人| 国产精品丝袜白浆摸在线| 伊人伊成久久人综合网站| 九九视频这里只有精品| 日韩av电影国产| 欧美成人小视频| 国产精品国产自产拍高清av水多| 日本伊人精品一区二区三区介绍| 一区二区日韩精品| 精品小视频在线| 久久久久久久激情视频| 亚洲激情电影中文字幕| 久久影视电视剧凤归四时歌| 国产视频久久久久久久| 一本色道久久综合狠狠躁篇怎么玩| 亚洲福利在线视频| 国产久一一精品| www.xxxx精品| 国产精品一区久久| 亚洲电影免费观看高清完整版在线观看| 黄色成人av网| 91理论片午午论夜理片久久| 亚洲日本成人女熟在线观看| 国产成人精品av| 欧美人在线观看| 亚洲日本中文字幕| 国产精品2018| 亚洲免费中文字幕| 久久99精品久久久久久青青91| 精品国产户外野外| 欧美国产日产韩国视频| 国模私拍一区二区三区| 亚洲性夜色噜噜噜7777| 日韩中文字幕av| 亚洲一区美女视频在线观看免费| 91精品视频专区| 日韩欧美极品在线观看| 清纯唯美日韩制服另类| 国产做受高潮69| 久久久久亚洲精品| 亚洲女人天堂色在线7777| 国产欧美日韩丝袜精品一区| 成人精品视频在线| 91亚洲va在线va天堂va国| 国产日韩欧美日韩| 国产精品久久久久久久久粉嫩av| 国产精品中文久久久久久久| 久久中文字幕国产| 中文字幕国产亚洲| 国产精品国内视频| 精品国产福利视频| 97在线看福利| 精品国产美女在线| 国产精品人成电影在线观看| 日韩成人在线播放| 久久777国产线看观看精品| 91夜夜未满十八勿入爽爽影院| 亚洲欧美激情在线视频| 精品视频偷偷看在线观看| 伊人伊人伊人久久| 国产免费观看久久黄| 97在线精品视频| 国产精品久久久久久搜索| 色哟哟入口国产精品| 91av福利视频| 国产日韩欧美在线看| 97色在线视频| 欧美亚洲激情视频| 亚洲第一页中文字幕| 亚洲欧美国产一本综合首页| 国产精品嫩草影院一区二区| 久久久久久一区二区三区| 九九热这里只有在线精品视| 疯狂蹂躏欧美一区二区精品| 精品高清一区二区三区| 91九色精品视频| 中文字幕日韩综合av| 91探花福利精品国产自产在线| 亚洲电影免费观看| 成人av色在线观看| 欧美激情精品久久久久久黑人| 国产欧美一区二区三区在线| 2019国产精品自在线拍国产不卡| 欧美精品激情在线观看| 国产成人啪精品视频免费网| 亚洲成人中文字幕| 韩国国内大量揄拍精品视频| 国产欧美一区二区白浆黑人| 欧美在线精品免播放器视频| 中文字幕在线看视频国产欧美| 亚洲日本成人网| 国产精品三级久久久久久电影| 国产精品一区二区三区成人| 精品国偷自产在线视频99| 国产精品视频中文字幕91| 欧美精品videossex性护士| 精品少妇一区二区30p| 97香蕉超级碰碰久久免费的优势| 91精品免费看| 亚洲人av在线影院| 亚洲大尺度美女在线| 日韩a**站在线观看| 成人黄色av网| 欧美xxxx18性欧美| 欧美剧在线观看| 国产欧美一区二区| 欧美中文字幕第一页| 久久精品99无色码中文字幕| 欧美乱妇40p| 国产亚洲一区二区精品| 色阁综合伊人av| 日本一区二区三区四区视频| 91成人国产在线观看| 国产精品亚洲一区二区三区| 成人做爰www免费看视频网站| 中文字幕国产亚洲2019| 日韩美女免费观看| 91精品国产综合久久香蕉的用户体验| 中文字幕自拍vr一区二区三区| 亚洲精品一区二三区不卡| 国产不卡在线观看| 国产ts人妖一区二区三区| 亚洲一区二区三区乱码aⅴ| 国产精品欧美风情| 中国人与牲禽动交精品| 日韩成人在线免费观看| 2021久久精品国产99国产精品| 不卡av电影在线观看| 久久亚洲精品网站| 国产不卡精品视男人的天堂| 亚洲国产私拍精品国模在线观看| 久久av在线看| 国产91对白在线播放| 2019中文字幕在线观看| 国产精品视频午夜| 欧美日韩性生活视频| 亚洲欧洲一区二区三区久久| 亚洲第一福利网站| 亚洲国产成人久久综合一区| 国内揄拍国内精品| 精品亚洲夜色av98在线观看| 国产日产欧美精品| 欧美日韩国产专区| 97免费中文视频在线观看| 国产日韩欧美成人| 久久亚洲国产精品| 日本亚洲精品在线观看| 精品无人区太爽高潮在线播放| 欧美国产中文字幕| 亚洲 日韩 国产第一| 亚洲欧美日韩国产中文| 午夜精品免费视频| 庆余年2免费日韩剧观看大牛| 亚洲少妇中文在线| 久久久视频精品| 一区二区欧美亚洲| 中文字幕亚洲欧美在线| 欧美日韩国产va另类| 国产精品v片在线观看不卡|