二叉树的遍历

遍历概念

  所谓遍历(Traversal)是指沿着某条搜索路线 依次对树中每个结点均做一次且仅做一次访问 访问结点所做的操作依赖于具体的应用问题   遍历是二叉树上最重要的运算之一 是二叉树上进行其它运算之基础

遍历方案

.遍历方案   从二叉树的递归定义可知 一棵非空的二叉树由根结点及左 右子树这三个基本部分组成 因此 在任一给定结点上 可以按某种次序执行三个操作    ( )访问结点本身(N)    ( )遍历该结点的左子树(L)    ( )遍历该结点的右子树(R) 以上三种操作有六种执行次序      NLR LNR LRN NRL RNL RLN   注意   前三种次序与后三种次序对称 故只讨论先左后右的前三种次序

.三种遍历的命名   根据访问结点操作发生位置命名   ① NLR 前序遍历(PreorderTraversal亦称(先序遍历))   ——访问结点的操作发生在遍历其左右子树之前   ② LNR 中序遍历(InorderTraversal)   ——访问结点的操作发生在遍历其左右子树之中(间)   ③ LRN 后序遍历(PostorderTraversal)   ——访问结点的操作发生在遍历其左右子树之后   注意   由于被访问的结点必是某子树的根 所以N(Node) L(Left subtlee)和R(Right subtree)又可解释为根 根的左子树和根的右子树 NLR LNR和LRN分别又称为先根遍历 中根遍历和后根遍历

遍历算法

.中序遍历的递归算法定义   若二叉树非空 则依次执行如下操作     ( )遍历左子树     ( )访问根结点     ( )遍历右子树

.先序遍历的递归算法定义   若二叉树非空 则依次执行如下操作     ( ) 访问根结点     ( ) 遍历左子树     ( ) 遍历右子树

.后序遍历得递归算法定义   若二叉树非空 则依次执行如下操作     ( )遍历左子树     ( )遍历右子树     ( )访问根结点

.中序遍历的算法实现   用二叉链表做为存储结构 中序遍历算法可描述为       void InOrder(BinTree T)        { //算法里①~⑥是为了说明执行过程加入的标号          ① if(T) { // 如果二叉树非空          ②    InOrder(T >lchild)           ③    printf( %c T >data) // 访问结点          ④    InOrder(T >rchild);          ⑤  }          ⑥ } // InOrder

遍历序列

.遍历二叉树的执行踪迹   三种递归遍历算法的搜索路线相同(如下图虚线所示) 具体线路为   从根结点出发 逆时针沿着二叉树外缘移动 对每个结点均途径三次 最后回到根结点        .遍历序列 ( ) 中序序列   中序遍历二叉树时 对结点的访问次序为中序序列  【例】中序遍历上图所示的二叉树时 得到的中序序列为                 D B A E C F ( ) 先序序列   先序遍历二叉树时 对结点的访问次序为先序序列  【例】先序遍历上图所示的二叉树时 得到的先序序列为                 A B D C E F ( ) 后序序列   后序遍历二叉树时 对结点的访问次序为后序序列  【例】后序遍历上图所示的二叉树时 得到的后序序列为                 D B E F C A  注意   ( ) 在搜索路线中 若访问结点均是第一次经过结点时进行的 则是前序遍历 若访问结点均是在第二次(或第三次)经过结点时进行的 则是中序遍历(或后序遍历) 只要将搜索路线上所有在第一次 第二次和第三次经过的结点分别列表 即可分别得到该二叉树的前序序列 中序序列和后序序列   ( ) 上述三种序列都是线性序列 有且仅有一个开始结点和一个终端结点 其余结点都有且仅有一个前趋结点和一个后继结点 为了区别于树形结构中前趋(即双亲)结点和后继(即孩子)结点的概念 对上述三种线性序列 要在某结点的前趋和后继之前冠以其遍历次序名称   【例】上图所示的二叉树中结点C 其前序前趋结点是D 前序后继结点是E 中序前趋结点是E 中序后继结点是F 后序前趋结点是F 后序后继结点是A 但是就该树的逻辑结构而言 C的前趋结点是A 后继结点是E和F

二叉链表的构造

. 基本思想   基于先序遍历的构造 即以二叉树的先序序列为输入构造   注意   先序序列中必须加入虚结点以示空指针的位置  【例】  建立上图所示二叉树 其输入的先序序列是 ABD∮∮CE∮∮F∮∮



  • 浜屽弶鏍戠殑涓牴閬嶅巻搴忓垪鏄粈涔?
    绛旓細宸茬煡鏌浜屽弶鏍戠殑涓牴閬嶅巻搴忓垪鏄疉BCDEFG,鍚庢牴閬嶅巻搴忓垪鏄疊DCAFGE,鍒欏畠鐨勫厛璺熼亶鍘嗗簭鍒楁槸锛欵ACBDGF銆傞鍏堟槑纭厛璺熼亶鍘嗭細涓乏鍙筹紱涓牴閬嶅巻锛氬乏涓彸锛涘悗鏍归亶鍘嗭細宸﹀彸涓1銆佸悗鏍归亶鍘嗘槑纭牴鑺傜偣鏄疎,涓牴閬嶅巻纭畾宸﹀瓙鏍戞槸ABCD锛屽彸瀛愭爲涓婃槸FG锛2銆佸悗搴忛亶鍘嗭紝A鏄乏瀛愭爲鐨勬牴锛岀劧鍚庡湪涓簭閲孉BCD鍒ゆ柇A娌℃湁宸...
  • 浜屽弶鏍戠殑鍏堟牴閬嶅巻,涓牴閬嶅巻鍜屽悗鏍归亶鍘
    绛旓細涔熸槸棣栭夐掑綊鐨勯亶鍘 閬嶅巻浜屽弶鏍 瀹冪殑鍩烘湰鎬濇兂鏄厛鎸夌収涓婇潰鐨勫舰寮忔妸鏁存5浜屽弶鏍戝垝鍒嗕负3閮ㄥ垎 鍝箞鎺ヤ笅鏉ョ殑宸ヤ綔灏卞緢绠鍗曚簡 鎴戜滑鍙渶瑕佸皢杩3閮ㄥ垎閮介亶鍘嗕竴閬嶅氨鍙互浜嗭紙杩欓噷鐢ㄥ埌浜嗗垎鑰屾不涔嬬殑鎬濇兂锛夎屽浜庤繖3閮ㄥ垎鏉ヨ 鏍硅妭鐐圭殑閬嶅巻鏃犵枒鏄渶鏂逛究鐨勶紝鐩存帴璁块棶灏眔k浜 鑰屽浜庡乏鍙冲瓙鏍戝憿锛熸垜浠笉闅惧彂鐜帮紝宸﹀彸瀛愭爲...
  • 浜屽弶鏍戠殑鍚庡簭閬嶅巻搴忓垪涓?
    绛旓細璇﹁В涓猴細鍓嶅簭搴忓垪鐨勯『搴忔槸鏍广佸乏銆佸彸锛屽簭鍒桝BCD绗竴涓竴瀹氭槸鏍圭粨鐐癸紝A鏄牴鑺傜偣銆備腑搴忓簭鍒楅『搴忔槸宸︺佹牴銆佸彸锛屽洜涓篈鏄牴鑺傜偣锛屾墍浠CB浣嶄簬A宸︿晶锛孉鍙充晶娌℃湁缁撶偣锛孊鏄疍CB涓変釜缁撶偣涓殑鏍广傚墠搴忓簭鍒楁槸涓乏鍙筹紝鏍圭粨鐐逛负A锛涗腑搴忓簭鍒楁槸宸︿腑鍙筹紝宸﹀瓙鏍態CD锛涢伒寰閬嶅巻搴忓垪鐨勮鍒欐帓鍒楀嚭浜屽弶鏍锛屽緱鍑哄悗搴忛亶鍘...
  • 鏍戠殑鍏堝簭閬嶅巻涓浜屽弶鏍戠殑鍏堝簭閬嶅巻鏄浉鍚岀殑鍚?
    绛旓細鏍戠殑鍏堟牴閬嶅巻鍜浜屽弶鏍戠殑鍏堝簭閬嶅巻鐩稿悓锛屽悗鏍归亶鍘嗕笌浜屽弶鏍戠殑涓簭閬嶅巻鐩稿悓銆備簩鍙夋爲锛圔inary tree锛夋槸鏍戝舰缁撴瀯鐨勪竴涓噸瑕佺被鍨嬨傝澶氬疄闄呴棶棰樻娊璞″嚭鏉ョ殑鏁版嵁缁撴瀯寰寰鏄簩鍙夋爲褰㈠紡锛屽嵆浣挎槸涓鑸殑鏍戜篃鑳界畝鍗曞湴杞崲涓轰簩鍙夋爲锛岃屼笖浜屽弶鏍戠殑瀛樺偍缁撴瀯鍙婂叾绠楁硶閮借緝涓虹畝鍗曪紝鍥犳浜屽弶鏍戞樉寰楃壒鍒噸瑕併備簩鍙夋爲鐗圭偣鏄瘡涓粨鐐...
  • 浜屽弶鏍戠殑閬嶅巻
    绛旓細瀵逛换鎰忕粰瀹氱殑浜屽弶鏍(椤剁偣鏁拌嚜瀹)寤虹珛瀹冪殑浜屽弶閾捐〃瀛樺偍缁撴瀯,骞跺埄鐢ㄦ爤鐨勪簲绉嶅熀鏈繍绠(缃┖鏍堛佽繘鏍堛佸嚭鏍堛佸彇鏍堥《鍏冪礌銆佸垽鏍堢┖)瀹炵幇浜屽弶鏍戠殑鍏堝簭銆佷腑搴忋佸悗搴忎笁绉閬嶅巻,杈撳嚭涓夌閬... 瀵逛换鎰忕粰瀹氱殑浜屽弶鏍(椤剁偣鏁拌嚜瀹)寤虹珛瀹冪殑浜屽弶閾捐〃瀛樺偍缁撴瀯,骞跺埄鐢ㄦ爤鐨勪簲绉嶅熀鏈繍绠(缃┖鏍堛佽繘鏍堛佸嚭鏍堛佸彇鏍堥《鍏冪礌銆佸垽...
  • 浜屽弶鏍戠殑娣卞害閬嶅巻鍜屽箍搴﹂亶鍘
    绛旓細鎴戜滑閫氳繃涓嬮潰鐨勮繖涓浜屽弶鏍鏉ョ畝鍗曠殑鐢诲浘瀹炵幇鏍堢殑娣卞害浼樺厛鎼滅储 褰撴垜浠湪鍘嬫爤鏃讹紝蹇呴』纭繚璇ヨ妭鐐圭殑宸﹀彸瀛愭爲閮戒负绌猴紝濡傛灉涓嶄负绌哄氨闇瑕佸厛灏嗗畠鐨勫彸瀛愭爲鍘嬫爤锛屽啀灏嗗乏瀛愭爲鍘嬫爤銆傜瓑宸﹀彸瀛愭爲閮藉帇鏍堜箣鍚庯紝鎵嶅皢缁撶偣鍘嬫爤銆傝В鍐虫柟妗 浠庢牴鑺傜偣寮濮嬶紝娌跨潃鏍戠殑瀹藉害閬嶅巻鏍戠殑鑺傜偣锛岀洿鍒版墍鏈夎妭鐐归兘琚亶鍘嗗畬涓烘銆傚洜涓烘槸鎸夌収...
  • 浠涔堝彨鍋浜屽弶鏍戠殑鍚庡簭閬嶅巻?
    绛旓細绔紝鎵浠G鏄疐鐨勫彸瀛愭爲锛5銆佺敱浜嶩銆丟鍦ㄥ悗搴閬嶅巻搴忓垪G鏈鍚庡嚭鐜帮紝鎵浠鏄疕, G涓殑鏍癸紝鍐嶇湅 涓簭涓璆宸︾鍙湁涓涓狧锛屾墍浠鏄疓鐨勫乏瀛愭爲锛屽緱鍒版渶缁堝師濮浜屽弶鏍銆傞渶瑕佹敞鎰忕殑鍑犵偣锛1銆佹牴鏄浉瀵圭殑锛屽浜庢暣妫垫爲鑰岃█鍙湁涓涓牴锛屼絾瀵逛簬姣忔5瀛愭爲鑰岃█锛屽張鏈夎嚜宸辩殑鏍广2銆佸墠搴忛亶鍘嗘椂锛屼竴妫鏍戠殑鏍规案杩滃湪宸...
  • 浜屽弶鏍戦亶鍘缁撳悎渚嬪瓙鍏蜂綋璁茶В渚嬪瓙涓嶈兘澶畝鍗
    绛旓細閬嶅巻鐨勬柟娉曟湁锛氬眰搴忛亶鍘嗐佸厛搴忛亶鍘嗐佷腑搴忛亶鍘嗐佸悗搴忛亶鍘嗙瓑锛屼互涓嬮潰鐨浜屽弶鏍涓轰緥浠嬬粛閬嶅巻 E / \ B F / \ \ A D H / / \ C G I \ K / J 1.灞傚簭閬嶅巻 鍗充粠涓婂埌涓嬫寜灞傛璁块棶璇ユ爲锛屾瘡涓灞傚崟鐙緭鍑轰竴琛岋紝姣忎竴灞傝姹傝闂殑椤哄簭涓轰粠宸﹀埌鍙炽備緥瀛愪腑灞傚簭閬嶅巻...
  • 浜屽弶鏍涓簭閬嶅巻鎬庝箞鐪?
    绛旓細\ B F / \ C D \ E 涓簭涓 A 涓嶧涔嬮棿娌℃湁锛岃鏄嶧娌℃湁宸﹀瓙鏍戯紝鍙湁鍙冲瓙鏍.濡備笂闈㈡柟娉曠户缁垎鏋怗HIJ锛屾渶缁浜屽弶鏍濡備笅锛欰 / \ B F / \ \ C D G \ / \ E H J \ I
  • 濡傛灉涓妫浜屽弶鏍戠殑涓簭搴忓垪鍜屽悗搴忓簭鍒楀垎鍒负CDBEAGHFK鍜孌CEBHGKFA,鍒欒...
    绛旓細銆愮瓟妗堛戯細D 鏈鑰冩煡浜屽弶鏍戠殑閬嶅巻鍜屼簩鍙夋爲鐨勪竴浜涙ц川銆備簩鍙夋爲鏄竴涓粨鐐规渶澶氬彧鏈変袱涓効瀛愮粨鐐圭殑鏍戯紝鍏朵簩鍙夋爲閬嶅巻鏈3绉嶅舰寮忥細(1)鍓嶅簭閬嶅巻锛氶鍏堣闂牴缁撶偣锛岀劧鍚庢寜鍓嶅簭閬嶅巻鏍圭粨鐐圭殑宸﹀瓙鏍戯紝鍐嶆寜鍓嶅簭閬嶅巻鏍圭粨鐐圭殑鍙冲瓙鏍戙(2)涓簭閬嶅巻锛氶鍏堟寜涓簭閬嶅巻鏍圭粨鐐圭殑宸﹀瓙鏍戯紝鐒跺悗璁块棶鏍圭粨鐐癸紝鍐嶆寜涓簭...
  • 扩展阅读:二叉树遍历画图 ... 二叉树的非递归遍历 ... 二叉树的遍历流程图 ... 二叉树创建和遍历 ... 看懂二叉树的三种遍历 ... dfs遍历 ... 二叉树的度和结点图解 ... 二叉树遍历的三种方法 ... 二叉树的4种遍历方法图解 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网