您的位置:首页 > 其它

257. 二叉树的所有路径-leetcode

2020-09-01 13:36 155 查看
257. 二叉树的所有路径-leetcode .title { text-align: center; margin-bottom: 0.2em } .subtitle { text-align: center; font-size: medium; font-weight: bold; margin-top: 0 } .todo { font-family: monospace; color: rgba(255, 0, 0, 1) } .done { font-family: monospace; color: rgba(0, 128, 0, 1) } .priority { font-family: monospace; color: rgba(255, 165, 0, 1) } .tag { background-color: rgba(238, 238, 238, 1); font-family: monospace; padding: 2px; font-size: 80%; font-weight: normal } .timestamp { color: rgba(190, 190, 190, 1) } .timestamp-kwd { color: rgba(95, 158, 160, 1) } .org-right { margin-left: auto; margin-right: 0; text-align: right } .org-left { margin-left: 0; margin-right: auto; text-align: left } .org-center { margin-left: auto; margin-right: auto; text-align: center } .underline { text-decoration: underline } #postamble p, #preamble p { font-size: 90%; margin: 0.2em } p.verse { margin-left: 3% } pre { border: 1px solid rgba(204, 204, 204, 1); box-shadow: 3px 3px 3px rgba(238, 238, 238, 1); padding: 8pt; font-family: monospace; overflow: auto; margin: 1.2em } pre.src { position: relative; overflow: visible; padding-top: 1.2em } pre.src:before { display: none; position: absolute; background-color: rgba(255, 255, 255, 1); top: -10px; right: 10px; padding: 3px; border: 1px solid rgba(0, 0, 0, 1) } pre.src:hover:before { display: inline } pre.src-asymptote:before { content: "Asymptote" } pre.src-awk:before { content: "Awk" } pre.src-C:before { content: "C" } pre.src-clojure:before { content: "Clojure" } pre.src-css:before { content: "CSS" } pre.src-D:before { content: "D" } pre.src-ditaa:before { content: "ditaa" } pre.src-dot:before { content: "Graphviz" } pre.src-calc:before { content: "Emacs Calc" } pre.src-emacs-lisp:before { content: "Emacs Lisp" } pre.src-fortran:before { content: "Fortran" } pre.src-gnuplot:before { content: "gnuplot" } pre.src-haskell:before { content: "Haskell" } pre.src-hledger:before { content: "hledger" } pre.src-java:before { content: "Java" } pre.src-js:before { content: "Javascript" } pre.src-latex:before { content: "LaTeX" } pre.src-ledger:before { content: "Ledger" } pre.src-lisp:before { content: "Lisp" } pre.src-lilypond:before { content: "Lilypond" } pre.src-lua:before { content: "Lua" } pre.src-matlab:before { content: "MATLAB" } pre.src-mscgen:before { content: "Mscgen" } pre.src-ocaml:before { content: "Objective Caml" } pre.src-octave:before { content: "Octave" } pre.src-org:before { content: "Org mode" } pre.src-oz:before { content: "OZ" } pre.src-plantuml:before { content: "Plantuml" } pre.src-processing:before { content: "Processing.js" } pre.src-python:before { content: "Python" } pre.src-R:before { content: "R" } pre.src-ruby:before { content: "Ruby" } pre.src-sass:before { content: "Sass" } pre.src-scheme:before { content: "Scheme" } pre.src-screen:before { content: "Gnu Screen" } pre.src-sed:before { content: "Sed" } pre.src-sh:before { content: "shell" } pre.src-sql:before { content: "SQL" } pre.src-sqlite:before { content: "SQLite" } pre.src-forth:before { content: "Forth" } pre.src-io:before { content: "IO" } pre.src-J:before { content: "J" } pre.src-makefile:before { content: "Makefile" } pre.src-maxima:before { content: "Maxima" } pre.src-perl:before { content: "Perl" } pre.src-picolisp:before { content: "Pico Lisp" } pre.src-scala:before { content: "Scala" } pre.src-shell:before { content: "Shell Script" } pre.src-ebnf2ps:before { content: "ebfn2ps" } pre.src-cpp:before { content: "C++" } pre.src-abc:before { content: "ABC" } pre.src-coq:before { content: "Coq" } pre.src-groovy:before { content: "Groovy" } pre.src- ad8 bash:before { content: "bash" } pre.src-csh:before { content: "csh" } pre.src-ash:before { content: "ash" } pre.src-dash:before { content: "dash" } pre.src-ksh:before { content: "ksh" } pre.src-mksh:before { content: "mksh" } pre.src-posh:before { content: "posh" } pre.src-ada:before { content: "Ada" } pre.src-asm:before { content: "Assembler" } pre.src-caml:before { content: "Caml" } pre.src-delphi:before { content: "Delphi" } pre.src-html:before { content: "HTML" } pre.src-idl:before { content: "IDL" } pre.src-mercury:before { content: "Mercury" } pre.src-metapost:before { content: "MetaPost" } pre.src-modula-2:before { content: "Modula-2" } pre.src-pascal:before { content: "Pascal" } pre.src-ps:before { content: "PostScript" } pre.src-prolog:before { content: "Prolog" } pre.src-simula:before { content: "Simula" } pre.src-tcl:before { content: "tcl" } pre.src-tex:before { content: "TeX" } pre.src-plain-tex:before { content: "Plain TeX" } pre.src-verilog:before { content: "Verilog" } pre.src-vhdl:before { content: "VHDL" } pre.src-xml:before { content: "XML" } pre.src-nxml:before { content: "XML" } pre.src-conf:before { content: "Configuration File" } table { border-collapse: collapse } caption.t-above { caption-side: top } caption.t-bottom { caption-side: bottom } td, th { vertical-align: top } th.org-right { text-align: center } th.org-left { text-align: center } th.org-center { text-align: center } td.org-right { text-align: right } td.org-left { text-align: left } td.org-center { text-align: center } dt { font-weight: bold } .footpara { display: inline } .footdef { margin-bottom: 1em } .figure { padding: 1em } .figure p { text-align: center } .equation-container { display: table; text-align: center; width: 100% } .equation { vertical-align: middle } .equation-label { display: table-cell; text-align: right; vertical-align: middle } .inlinetask { padding: 10px; border: 2px solid rgba(128, 128, 128, 1); margin: 10px; background: rgba(255, 255, 204, 1) } #org-div-home-and-up { text-align: right; font-size: 70%; white-space: nowrap } textarea { overflow-x: auto } .linenr { font-size: smaller } .code-highlighted { background-color: rgba(255, 255, 0, 1) } .org-info-js_info-navigation { border-style: none } #org-info-js_console-label { font-size: 10px; font-weight: bold; white-space: nowrap } .org-info-js_search-highlight { background-color: rgba(255, 255, 0, 1); color: rgba(0, 0, 0, 1); font-weight: bold } .org-svg { width: 90% }

257. 二叉树的所有路径-leetcode

Table of Contents

1 题目

257. 二叉树的所有路径

2 代码

/**
* Definition for a binary tree node.
* class TreeNode {
*     public $val = null;
*     public $left = null;
*     public $right = null;
*     function __construct($value) { $this->val = $value; }
* }
*/
class Solution {
private $ret = [];

/**
* @param TreeNode $root
* @return String[]
*/
function binaryTreePaths($root) {
$this->ret = [];

if (empty($root)) {
return $this->ret;
}
$path = $root->val;
$this->dfs($root, $path, 1);

return $this->ret;
}

function dfs($root, $path, $isRoot = 0) {
if (! $isRoot) {
$path = $path."->".$root->val;
}
if (empty($root->left) && empty($root->right)) {
$this->ret[] = strval($path);
}
if ($root->left) {
$this->dfs($root->left, $path);
}
if ($root->right) {
$this->dfs($root->right, $path);
}
}
}

3 思路

深度优先遍历,或者广度优先遍历都可以

我这里加了一个函数的变量 isRoot,有点冗余,可以通过优化去掉

===

作者: 吴丹阳 https://www.cnblogs.com/wudanyang

更新时间: 2020-09-01 Tue 13:35

Emacs 27.1 (Org mode 9.3.7)

===

天行健,君子以自强不息。

地势坤,君子以厚德载物。

===

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: