日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Leetcode-199二叉树的右视图(二叉树左视图)

發(fā)布時(shí)間:2025/3/19 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Leetcode-199二叉树的右视图(二叉树左视图) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目描述

給定一個(gè)二叉樹(shù)的?根節(jié)點(diǎn)?root,想象自己站在它的右側(cè),按照從頂部到底部的順序,返回從右側(cè)所能看到的節(jié)點(diǎn)值。

輸入:?[1,2,3,null,5,null,4] 輸出:?[1,3,4] 輸入:?[1,null,3] 輸出:?[1,3] 輸入:?[] 輸出:?[]

解題思路

思路一:采用兩個(gè)隊(duì)列的方法,第一個(gè)隊(duì)列記錄第一層,第二個(gè)隊(duì)列記錄第二層。知道兩個(gè)隊(duì)列都為空的時(shí)候,遍歷結(jié)束。時(shí)間復(fù)雜度和空間復(fù)雜度都是O(N)

但這種方法有一個(gè)不太好的地方,就是代碼偏多,需要定義兩個(gè)隊(duì)列。面試官姐姐可能并不喜歡你的方法。

思路二:采用一個(gè)隊(duì)列+計(jì)數(shù)的方法,每個(gè)層次的遍歷,之前,都先統(tǒng)計(jì)一下這一層有多少個(gè)節(jié)點(diǎn)。如何統(tǒng)計(jì)呢?其實(shí)就是當(dāng)時(shí)隊(duì)列中元素的個(gè)數(shù)。例如,隊(duì)列有n個(gè)節(jié)點(diǎn),當(dāng)這一層級(jí)的第n個(gè)節(jié)目點(diǎn)出棧的時(shí)候,將該節(jié)點(diǎn)計(jì)入結(jié)果。

解題核心代碼

class Solution {public List<Integer> rightSideView(TreeNode root) {LinkedList<Integer> res = new LinkedList<>();if (root==null){return res;}LinkedList<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()){int size = queue.size();for (int i = 0;i<size;i++){if (i==size-1){res.offer(queue.peek().val);}TreeNode node = queue.poll();if (node.left!=null){queue.offer(node.left);}if (node.right!=null){queue.offer(node.right);}}}return res;} }

解題延申——求左視圖

求左視圖也非常簡(jiǎn)單

if (i==size-1)? 這一行 改為?if (i==0)

即可。

解題本地調(diào)試代碼

??

import java.util.LinkedList; import java.util.List; import java.util.Queue;public class Solution199 {public static void main(String[] args) {String line = "[1,2,3,null,5,null,4]";TreeNode root = stringToTreeNode(line);List<Integer> retRight = new Solution199().rightSideView(root);List<Integer> retLeft = new Solution199().leftSideView(root);String outRight = integerArrayListToString(retRight);String outLeft = integerArrayListToString(retLeft);System.out.println("二叉樹(shù)為:" + line);System.out.println("右視圖為:" + outRight);System.out.println("左視圖為:" + outLeft);}public static TreeNode stringToTreeNode(String input) {input = input.trim();input = input.substring(1, input.length() - 1);if (input.length() == 0) {return null;}String[] parts = input.split(",");String item = parts[0];TreeNode root = new TreeNode(Integer.parseInt(item));Queue<TreeNode> nodeQueue = new LinkedList<>();nodeQueue.add(root);int index = 1;while (!nodeQueue.isEmpty()) {TreeNode node = nodeQueue.remove();if (index == parts.length) {break;}item = parts[index++];item = item.trim();if (!item.equals("null")) {int leftNumber = Integer.parseInt(item);node.left = new TreeNode(leftNumber);nodeQueue.add(node.left);}if (index == parts.length) {break;}item = parts[index++];item = item.trim();if (!item.equals("null")) {int rightNumber = Integer.parseInt(item);node.right = new TreeNode(rightNumber);nodeQueue.add(node.right);}}return root;}public static String integerArrayListToString(List<Integer> nums, int length) {if (length == 0) {return "[]";}StringBuilder result = new StringBuilder();for (int index = 0; index < length; index++) {Integer number = nums.get(index);result.append(Integer.toString(number)).append(", ");}return "[" + result.substring(0, result.length() - 2) + "]";}public static String integerArrayListToString(List<Integer> nums) {return integerArrayListToString(nums, nums.size());}public List<Integer> rightSideView(TreeNode root) {LinkedList<Integer> res = new LinkedList<>();if (root == null) {return res;}LinkedList<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {int size = queue.size();for (int i = 0; i < size; i++) {if (i == size - 1) {res.offer(queue.peek().val);}TreeNode node = queue.poll();if (node.left != null) {queue.offer(node.left);}if (node.right != null) {queue.offer(node.right);}}}return res;}public List<Integer> leftSideView(TreeNode root) {LinkedList<Integer> res = new LinkedList<>();if (root == null) {return res;}LinkedList<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {int size = queue.size();for (int i = 0; i < size; i++) {if (i == 0) {res.offer(queue.peek().val);}TreeNode node = queue.poll();if (node.left != null) {queue.offer(node.left);}if (node.right != null) {queue.offer(node.right);}}}return res;} }class TreeNode {int val;TreeNode left;TreeNode right;TreeNode() {}TreeNode(int val) {this.val = val;}TreeNode(int val, TreeNode left, TreeNode right) {this.val = val;this.left = left;this.right = right;} }

輸出為

總結(jié)

以上是生活随笔為你收集整理的Leetcode-199二叉树的右视图(二叉树左视图)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美劲爆第一页 | 国产黄色91| 中文字幕 国产 | 欧美一级一级 | www.日日操| 蜜桃精品视频在线观看 | 日韩干| 亚洲天堂中文在线 | 97性视频| 国产色视频网站 | 国产毛片在线 | 国产精品最新 | 美女高潮视频在线观看 | 国产一区二区三区在线 | 99国内揄拍国内精品人妻免费 | 性av在线| 日韩激情视频在线观看 | 7x7x7x人成影视 | 8x8x国产精品一区二区 | 热久久中文字幕 | 老师用丝袜脚帮我脚交 | 欧洲一区在线 | 精品动漫一区二区三区的观看方式 | 天天狠狠 | 青草一区二区 | 亚洲成熟女性毛茸茸 | 欧美国产在线看 | 韩国一区二区视频 | 手机看片一区 | 麻豆精品免费视频 | 国产素人av | 国产色秀 | 蜜桃视频在线观看www | 自拍偷拍福利视频 | 国产女主播喷水高潮网红在线 | 亚洲自拍偷拍视频 | 精品一区二区三区免费观看 | 偷拍女澡堂一区二区三区 | 亚洲激情网 | 亚洲乱轮视频 | 国产三级高清 | 天天干天天操天天摸 | 国产一区二区三区18 | 又黄又爽视频 | 一本大道av伊人久久综合 | 性工作者十日谈 | 九九天堂网 | 就要干就要操 | 亚洲在线免费看 | 免费人妻精品一区二区三区 | 曰女同女同中文字幕 | 一本一道久久a久久精品综合 | 国产成人免费av一区二区午夜 | 人妻少妇被猛烈进入中文字幕 | 国产精品久久久久久久久动漫 | 欧美国产日韩一区 | 国产免费播放 | 日本欧美国产在线 | av福利在线 | 日韩欧美一区二区三区四区 | 日韩精品极品视频在线观看免费 | 非洲黑人狂躁日本妞 | 亚洲高清视频在线播放 | 日产精品久久久久 | 国产又粗又猛又黄又爽无遮挡 | 亚洲理论在线观看 | 中文字幕日韩一区二区三区不卡 | 国产探花一区二区 | 日本在线h | 四虎影视免费 | 激情午夜天 | 激情三区 | 午夜啪啪网站 | 日本不卡久久 | 99精品区 | 欧美a v在线播放 | javxxx| 亚洲熟伦熟女新五十路熟妇 | 114国产精品久久免费观看 | 狠狠干夜夜爽 | 日韩一区二区三区中文字幕 | 蜜臀久久99精品久久一区二区 | 国产乱淫av麻豆国产 | 精品日韩中文字幕 | 日韩在线成人 | 国产成人无码一区二区在线播放 | 亚洲国产成人一区二区精品区 | 黄色片xxx | 午夜激情小视频 | 五月天色综合 | 91久久| 91伊人网| 亚洲国产果冻传媒av在线观看 | 秋霞欧洲 | 国产精品久久久爽爽爽麻豆色哟哟 | 成人福利视频在线 | 国产精品高潮视频 | 狠狠人妻久久久久久综合蜜桃 | 欧美精品色 |