溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么執行C語言中二叉樹中序遍歷

發布時間:2020-07-16 10:00:15 來源:億速云 閱讀:620 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關怎么執行C語言中二叉樹中序遍歷,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

C語言中二叉樹中序遍歷的方法:首先遍歷左子樹,并借助遞歸繼續訪問直到最左側節點;然后訪問根結點;最后遍歷右子樹,并借助遞歸繼續訪問直到最右側節點即可。

C語言中二叉樹中序遍歷的方法:

中序遍歷的規則是:左子樹---> 根結點 ---> 右子樹。所以我們訪問節點的順序需要變。

  • 我們直到遞歸是來回的過程,對于恰好有兩個子節點(子節點無節點)的節點來說。只需要訪問一次左節點,訪問根,訪問右節點。即可。

  • 而如果兩側有節點來說。每個節點都要滿足中序遍歷的規則。我們從根先訪問左節點。到了左節點這兒左節點又變成一顆子樹,也要滿足中序遍歷要求。所以就要先訪問左節點的左節點(如果存在)。那么如果你這樣想,規則雖然懂了。但是也太復雜了。那么我們借助遞歸。因為它的子問題和根節點的問題一致,只是范圍減小了。所以我們使用遞歸思想來解決。

  • 那么遞歸的邏輯為:考慮特殊情況(特殊就直接訪問)不進行遞歸否則遞歸的訪問左子樹(讓左子樹執行相同函數,特殊就停止遞歸輸出,不特殊就一直找下去直到最左側節點。)——>輸出該節點—>遞歸的訪問右子樹.

public void zhongxu(node t)// 中序遍歷 中序遍歷:左子樹---> 根結點 ---> 右子樹
{
if (t != null) {
zhongxu(t.left);
System.out.print(t.value + " ");// 訪問完左節點訪問當前節點
zhongxu(t.right);
}
}


關于怎么執行C語言中二叉樹中序遍歷就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女