LeetCode 노트: 257.Binary Tree Paths
2905 단어 LeetCode
질문:
Given a binary tree, return all root-to-leaf paths.
For example, given the following binary tree:
1 /\ 2 3 \ 5
All root-to-leaf paths are:
[“1->2->5”, “1->3”]
대의:
두 갈래 나무를 제시하여 뿌리 노드에서 잎 노드까지의 모든 경로를 되돌려줍니다.
예를 들어 아래의 이 두 갈래 나무를 제시한다.
1 /\ 2 3 \ 5
루트 노드에서 잎 노드까지의 모든 경로는 다음과 같습니다.
[“1->2->5”, “1->3”]
생각:
이 문제는 귀속을 사용하기에 적합하다. 순서대로 좌우 잎사귀 노드가 있는지 판단하고 각각 귀속을 한다. 귀속에서 만나는 노드 값을 경로 문자열의 마지막에 연결하고'->'라는 내용을 붙여야 한다. 좌우 자노드가 없을 때까지 잎사귀 노드에 도착했다고 표시하면 끝낼 수 있다. 이 경로의 문자열을 결과에 추가해야 한다.
코드:
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */
public class Solution {
public List<String> binaryTreePaths(TreeNode root) {
List<String> result = new ArrayList<String>();
if (root == null) return result;
String path = String.valueOf(root.val);
findPath(result, root, path);
return result;
}
public void findPath(List<String> list, TreeNode root, String path) {
if (root.left == null && root.right == null) {
list.add(path);
return;
}
if (root.left != null) {
StringBuffer pathBuffer = new StringBuffer(path);
pathBuffer.append("->");
pathBuffer.append(String.valueOf(root.left.val));
findPath(list, root.left, pathBuffer.toString());
}
if (root.right != null) {
StringBuffer pathBuffer = new StringBuffer(path);
pathBuffer.append("->");
pathBuffer.append(String.valueOf(root.right.val));
findPath(list, root.right, pathBuffer.toString());
}
}
}
집합:https://github.com/Cloudox/LeetCode-Record저작권 소유:http://blog.csdn.net/cloudox_
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
python 문자열 입력으로 모든 유효한 IP 주소 생성(LeetCode 93번 문제)이 문제의 공식 난이도는 Medium으로 좋아요 1296, 반대 505, 통과율 35.4%를 눌렀다.각 항목의 지표로 말하자면 보기에는 약간 규범에 맞는 것 같지만, 실제로도 확실히 그렇다.이 문제의 해법과 의도는 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.