a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

C語言二叉樹的非遞歸遍歷實例分析

2020-01-26 15:19:07
字體:
來源:轉載
供稿:網友

本文以實例形式講述了C語言實現二叉樹的非遞歸遍歷方法。是數據結構與算法設計中常用的技巧。分享給大家供大家參考。具體方法如下:

先序遍歷:

void preOrder(Node *p) //非遞歸{  if(!p) return;  stack<Node*> s;  Node *t;  s.push(p);  while(!s.empty())  {    t=s.top();    printf("%d/n",t->data);    s.pop();    if(t->right) s.push(t->right);    if(t->left) s.push(t->left);  }}

中序遍歷:

void inOrder(Node *p){if(!p)return;stack< pair<Node*,int> > s;Node *t;int unUsed;s.push(make_pair(p,1));while(!s.empty()){t=s.top().first;unUsed = s.top().second;s.pop();if(unUsed){if(t->right)s.push( make_pair(t->right,1) );s.push( make_pair(t,0) );if(t->left)s.push( make_pair(t->left,1));}else printf("%d/n",t->data);}}

后序遍歷:

void postOrder(Node *p){  if(!p) return;  stack<pair<Node*,int> > s;  Node *t;  int unUsed;  s.push(make_pair(p,1));  while(!s.empty())  {    t=s.top().first;    unUsed=s.top().second;    s.pop();    if(unUsed)    {      s.push(make_pair(t,0);      if(t->right)        s.push(make_pair(t->right,1));      if(t->left)        s.push(make_pair(t->left,1));    }    else printf("%d/n",t->data);  }}

希望本文所述對大家C程序算法設計的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 国产一区二区三区久久久 | 久久久久久亚洲精品中文字幕 | 成人毛片在线视频 | 久久久久久久影院 | 国产特黄 | 天堂一区二区三区四区 | ww8888免费视频 | 欧美精品欧美极品欧美激情 | 欧美一区二区三区国产精品 | 日韩性视频 | 中文字幕第80页 | 天天夜碰日日摸日日澡 | 黄av在线 | 欧美日韩视频一区二区 | 欧美三级电影在线观看 | 亚洲精品一区二区三区蜜桃久 | 国产精品国产精品国产专区不卡 | 国产精品成人3p一区二区三区 | 国产九九精品 | 性生生活大片免费看视频 | 国产美女一区二区 | 一区在线看 | 日产精品久久久一区二区 | 亚洲国产精品第一区二区 | 成人黄色电影在线观看 | 国产精品久久久久久久久久免费看 | 亚洲久久 | 国产一区二区视频在线观看 | 久久国产精品一区 | 久操国产 | 日韩免费激情视频 | 久久久999| 毛片网子| 欧美大片在线看免费观看 | 午夜香蕉视频 | 欧美一区二区三区在线观看视频 | 国产一区二区三区久久99 | 一区二区中文 | 久久国产一区二区三区 | 久久精品日产高清版的功能介绍 | 国产青草 |