成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

【Leetcode】103. 二叉樹的鋸齒形層次遍歷

XiNGRZ / 3061人閱讀

摘要:題目給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值的鋸齒形層次遍歷。例如給定二叉樹返回鋸齒形層次遍歷如下題解這道題要求用字型就是要求知道深度。稍作改動(dòng)的是需要在遍歷左子樹和右子樹的時(shí)候帶上深度的信息,才能知道是加在列表頭還是列表尾部。

題目

給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值的鋸齒形層次遍歷。(即先從左往右,再?gòu)挠彝筮M(jìn)行下一層遍歷,以此類推,層與層之間交替進(jìn)行)。

例如:
給定二叉樹 [3,9,20,null,null,15,7],

    3
   / 
  9  20
    /  
   15   7

返回鋸齒形層次遍歷如下:

[
  [3],
  [20,9],
  [15,7]
]
題解

這道題要求用z字型,就是要求知道深度。因?yàn)橹郎疃任覀兙涂梢愿鶕?jù)深度的奇偶來(lái)判斷如何打印。
首先相到的就是層序遍歷,然后記錄是第幾層。層序遍歷用隊(duì)列的代碼我們已經(jīng)很熟悉了。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public List> zigzagLevelOrder(TreeNode root) {
        List> res = new LinkedList<>();
        if (root == null) {
            return res;
        }
        LinkedList queue = new LinkedList<>();
        queue.add(root);
        int depth = 0;
        while (!queue.isEmpty()) {
            int size = queue.size();
            LinkedList currentRes = new LinkedList<>();
            // 當(dāng)前層一直出隊(duì).
            while (size > 0) {
                TreeNode current = queue.poll();
                TreeNode left = current.left;
                TreeNode right = current.right;
                if (left != null) {
                    queue.add(left);
                }
                if (right != null) {
                    queue.add(right);
                }
                // 奇數(shù)層,從頭添加; 偶數(shù)層從尾部添加.
                if (depth % 2 != 0) {
                    currentRes.add(0, current.val);
                } else {
                    currentRes.add(current.val);
                }
                size--;
            }
            // 把當(dāng)前層遍歷的結(jié)果加入到結(jié)果中.
            res.add(currentRes);
            depth++;
        }
        return res;
    }
}

同之前一樣,我們想一想有沒有遞歸的解法.
我們可以采用先序遍歷的方式,先遍歷節(jié)點(diǎn),然后遞歸的遍歷左子樹和右子樹。
稍作改動(dòng)的是,需要在遍歷左子樹和右子樹的時(shí)候帶上深度的信息,才能知道是加在列表頭還是列表尾部。
遞歸的結(jié)束條件就是遇到空節(jié)點(diǎn)。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public List> zigzagLevelOrder(TreeNode root) {
        List> res = new LinkedList<>();
        if (root == null) {
            return res;
        }
        helper(res, root, 0);
        return res;
    }

    public void helper(List> res,TreeNode root, int depth) {
        if (root == null) {
            return;
        }
        // 注意這里new List, 說(shuō)明當(dāng)前節(jié)點(diǎn)遞歸進(jìn)入了新的層.
        if (res.size() <= depth) {
            res.add(new LinkedList<>());
        }
        
        if (depth % 2 != 0) {
            res.get(depth).add(0, root.val);
        } else {
            res.get(depth).add(root.val);
        }

        helper(res, root.left, depth + 1);
        helper(res, root.right, depth + 1);
    }
}
熱門閱讀

技術(shù)文章匯總

【Leetcode】101. 對(duì)稱二叉樹

【Leetcode】100. 相同的樹

【Leetcode】98. 驗(yàn)證二叉搜索樹

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/73450.html

相關(guān)文章

  • 力扣(LeetCode)103

    摘要:題目地址題目描述給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值的鋸齒形層次遍歷。即先從左往右,再?gòu)挠彝筮M(jìn)行下一層遍歷,以此類推,層與層之間交替進(jìn)行。解答二叉樹的層序遍歷,只不過對(duì)于偶數(shù)層來(lái)說(shuō),把該層的遍歷結(jié)果轉(zhuǎn)置一下就行了。 題目地址:https://leetcode-cn.com/probl...題目描述:給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值的鋸齒形層次遍歷。(即先從左往右,再?gòu)挠彝筮M(jìn)行下一層遍歷,以此類...

    ZHAO_ 評(píng)論0 收藏0
  • LeetCode 精選TOP面試題【51 ~ 100】

    摘要:有效三角形的個(gè)數(shù)雙指針最暴力的方法應(yīng)該是三重循環(huán)枚舉三個(gè)數(shù)字??偨Y(jié)本題和三數(shù)之和很像,都是三個(gè)數(shù)加和為某一個(gè)值。所以我們可以使用歸并排序來(lái)解決這個(gè)問題。注意因?yàn)闅w并排序需要遞歸,所以空間復(fù)雜度為 ...

    Clect 評(píng)論0 收藏0
  • Leetcode】102. 二叉樹的層次遍歷

    摘要:題目給定一個(gè)二叉樹,返回其按層次遍歷的節(jié)點(diǎn)值。例如給定二叉樹返回其層次遍歷結(jié)果題解我們數(shù)據(jù)結(jié)構(gòu)的書上教的層序遍歷就是利用一個(gè)隊(duì)列不斷的把左子樹和右子樹入隊(duì)。 題目 給定一個(gè)二叉樹,返回其按層次遍歷的節(jié)點(diǎn)值。 (即逐層地,從左到右訪問所有節(jié)點(diǎn))。 例如:給定二叉樹: [3,9,20,null,null,15,7], 3 / 9 20 / 15 ...

    feng409 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<