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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【算法刷题1】二叉树的前序遍历

發布時間:2025/3/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【算法刷题1】二叉树的前序遍历 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

解題思路

什么是二叉樹的前序遍歷?簡單來說就是“根左右”,展開來說就是對于一顆二叉樹優先訪問其根節點,然后訪問它的左子樹,等左子樹全部訪問完了再訪問其右子樹,而對于子樹也按照之前的訪問方式,直到到達葉子節點。

從上述前序遍歷的解釋中我們不難發現,它存在遞歸的子問題:每次訪問一個節點之后,它的左子樹是一個要前序遍歷的子問題,它的右子樹同樣是一個要前序遍歷的子問題。那我們可以用遞歸處理:

終止條件: 當子問題到達葉子節點后,后一個不管左右都是空,因此遇到空節點就返回。
返回值:每次處理完子問題后,就是將子問題訪問過的元素返回,依次存入了數組中。
本級任務:每個子問題優先訪問這棵子樹的根節點,然后遞歸進入左子樹和右子樹。

因此處理的時候,過程就是:

step 1:準備數組用來記錄遍歷到的節點值,Java可以用List,C++可以直接用vector。
step 2:從根節點開始進入遞歸,遇到空節點就返回,否則將該節點值加入數組。
step 3:依次進入左右子樹進行遞歸。

import java.util.*;/** public class TreeNode {* int val = 0;* TreeNode left = null;* TreeNode right = null;* public TreeNode(int val) {* this.val = val;* }* }*/public class Solution {List<Integer> list = new ArrayList<>();/*** 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可** * @param root TreeNode類 * @return int整型一維數組*/public int[] preorderTraversal (TreeNode root) {// write code hereList<Integer> list = preOrder(root);int[] res = new int[list.size()];for(int i = 0;i<list.size();i++){res[i]=list.get(i);}return res;}List<Integer> preOrder(TreeNode node ){if(node == null){return list;}list.add(node.val);preOrder(node.left);preOrder(node.right);return list;}}

總結

以上是生活随笔為你收集整理的【算法刷题1】二叉树的前序遍历的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。