LeetCode - Path Sum II

来源:http://www.cnblogs.com/shuaiwhu/archive/2016/01/10/5118320.html
-Advertisement-
Play Games

題目:Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given sum.For example:Given the below binary tree and s...


題目:

Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given sum.

For example:
Given the below binary tree and sum = 22,

              5
             / \
            4   8
           /   / \
          11  13  4
         /  \    / \
        7    2  5   1

return

[
   [5,4,11,2],
   [5,8,4,5]
]

思路:

註意必須到 leaf node

package tree;

import java.util.ArrayList;
import java.util.List;

public class PathSumII {
    
    public List<List<Integer>> pathSum(TreeNode root, int sum) {
        List<List<Integer>> res = new ArrayList<List<Integer>>();
        if (root == null) return res;
        List<Integer> record = new ArrayList<Integer>();
        pathSum(res, record, root, sum);
        return res;
    }
    
    private void pathSum(List<List<Integer>> res, List<Integer> record, TreeNode root, int sum) {
        if (root == null && sum != 0) return;
        if (root == null && sum == 0) {
            res.add(record);
        } else {
            if (root.left == null || root.right == null) {
                List<Integer> newRecord = new ArrayList<Integer>(record);
                newRecord.add(root.val);
                pathSum(res, newRecord, root.left == null ? root.right : root.left, sum - root.val);
            } else {
                List<Integer> newRecord1 = new ArrayList<Integer>(record);
                newRecord1.add(root.val);
                pathSum(res, newRecord1, root.left, sum - root.val);
                List<Integer> newRecord2 = new ArrayList<Integer>(record);
                newRecord2.add(root.val);
                pathSum(res, newRecord2, root.right, sum - root.val);
            }
        }
    }
    
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先javascript不是瀏覽器的附屬品,只能說它大多數的運行環境是在瀏覽器中的,但又不僅僅局限於瀏覽器中。它是一門真正的程式設計語言,在這方面它和java、c、c++、c#是等同的,只不過它不直接和操作系統打交道,這也是它相比於其他語言有些特殊和看似簡單的地方。這種問題的根源在於它的翻譯器,.....
  • 慕課網學到的用css3製作立體導航,受益匪淺,配合前段時間學的二級導航,有空試,哈哈!內容簡單,但偽類after的使用需要註意!經過修改的最終效果圖:涉及css3的知識點包括:圓角特效:border-radius: 10px;盒子陰影:box-shadow: 2px 5px 0px #0000cc;...
  • 作者:^_^肥仔John 來源:CSS3魔法堂:CSS3濾鏡及Canvas、SVG和IE濾鏡替代方案詳解IE特有的濾鏡常常作為CSS3各種新特性的降級處理補充,而Adobe轉向HTML5後與Chrome合作推出CSS3的Filter特性,因此當前僅Webkit內核的瀏覽器支持CSS3 Filter....
  • 首先還是先感謝github,感謝github上提供此段源碼的作者。跟昨晚的來比今天的靜態文件伺服器有點點複雜些,可以學到很多新的東西。仔細會發現這次的代碼多了一個fs.stat函數和ReadStream對象的pipe函數,stat這個函數是用來獲取文件信息。第一個參數是傳入文件路徑,第二個則是回調函...
  • 一、引言 很久沒有寫過博客了,但是最近這段時間都沒有閑著,接觸了很多方面。比如一些前端框架和組件、還有移動開發React-Native、以及對.NET框架設計的一些重新認識。這些內容在接下來的時間都會一一和大家分享的。我為什麼放置了這麼久又重新寫博客呢?因為在這段時間裡面,我雖然接觸了這麼多東西,....
  • 意圖 0 適用性 1 結構 2 實現 3 效果 4 參考 5意圖將請求封裝成一個對象,客戶接受請求參數;可以對請求排隊或者記錄請求日誌,以及可以支持撤銷操作適用性抽象出待執行的動作以參數化某對象。命令模式是回調機制的一個面向對象的替代品在不同的時刻指定、排列和執行請求支持取消操作支持修...
  • In the latest Qt 5.5, the QOpenGLWidget is much better and has less bugs than the QGLWidget, but it doesn't supply the good API to retrieve the native...
  • 一轉眼又一年過去了,兩年沒回家了,下周回家看看!公司的項目已經開始內測了,再堅持三個月應該就能熬出頭了吧?然後自己的引擎和游戲就繼續開發,今年一定要出東西了!前些天狗被我喂上火了,眼裡流黃屎,嚇壞我了,趕緊黃瓜白菜一起才給輓救回來!之後就像遭報應一樣我病了,咽炎,感冒不止,現在還沒好,打了六針了!這...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...