多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > 《劍指offer》:[60]把二叉樹打印成多行

《劍指offer》:[60]把二叉樹打印成多行

來源:程序員人生   發布時間:2016-08-02 08:48:43 閱讀次數:2438次
題目:從上到下安層打印2叉樹,同1層的結點按從左到右的順序打印,每層打印1行。

例如,圖(1)中2叉樹和打印結果為:


這個題其實很簡單,我們只需要設置兩個變量就能夠弄定。1個變量表示當前層中還沒有打印的結點數,另外一個變量表示下1層結點的數目。
具體實現代碼以下:
#include <iostream> #include <queue> using namespace std; struct BinaryTree { int data; BinaryTree *pLeft; BinaryTree *pRight; }; BinaryTree *pRoot1=NULL; queue<BinaryTree *> node; void CreateTree(BinaryTree *&root) { int data; cin>>data; if(0==data) root=NULL; else { root=new BinaryTree; root->data=data; CreateTree(root->pLeft); CreateTree(root->pRight); } } void PrintTree(BinaryTree *root) { if(NULL==root) return; node.push(root); int nextlevel=0;//下1層的結點數; int tobePrinted=1;//當前還有幾個結點; while(!node.empty()) { BinaryTree *pNode=node.front(); cout<<pNode->data<<" "; if(pNode->pLeft!=NULL) { node.push(pNode->pLeft); nextlevel++; } if(pNode->pRight!=NULL) { node.push(pNode->pRight); nextlevel++; } node.pop();//入隊列的速度比出隊列的要快; tobePrinted--; if(tobePrinted==0) { cout<<endl;//1行打印完了,所以換行; tobePrinted=nextlevel; nextlevel=0; } } } int main() { CreateTree(pRoot1); cout<<"之字形打印以下:"<<endl; PrintTree(pRoot1); cout<<endl; system("pause"); return 0; }

運行結果以下:





生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 国产1区2区在线观看 | 手机在线成人精品视频网 | 欧美精品福利视频 | 亚洲精品不卡久久久久久 | 亚洲天堂网站在线 | a4yy私人毛片 | 国产精品一区伦免视频播放 | 久久无码精品一区二区三区 | 国内精品视频在线观看 | 中文在线1区二区六区 | 日韩欧美在线看 | 欧美成免费 | 欧美人与性禽xxxx | 欧美三级视频在线观看 | 欧美视频在线一区二区三区 | 在线影院福利 | 91福利院 | 九九久久久久午夜精选 | 最近免费中文字幕大全免费版视频 | 日本在线观看不卡免费视频 | 日韩在线视频不卡一区二区三区 | 国产精品第1页在线观看 | 精品番号 | 精品久久久久久亚洲 | 亚洲人成影院在线高清 | 国产人成亚洲第一网站在线播放 | 热久久视久久精品18国产 | 亚洲精品一区二区三区国产 | 美女免费网站在线视频 | 国产成人精品午夜在线播放 | 亚洲日本在线观看网址 | 日韩小视频在线播放 | 午夜欧美性欧美 | 看亚洲a级一级毛片 | ak福利午夜在线观看 | 欧美综合国产精品日韩一 | 精品一区二区三区四区在线 | 国产精品免费一区二区三区四区 | 波多野结衣久久精品 | 久久国产精品亚洲一区二区 | 日韩精品在线播放 |