두 갈래 나무의 앞 순서와 중간 순서 (귀속과 비귀속)
4031 단어 정렬
앞의 순서가 두루 미치다.
귀속판/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Preorder in ArrayList which contains node values.
*/
public List preorderTraversal(TreeNode root) {
List list = new ArrayList<>();
preorderTraversal(root, list);
return list;
}
public void preorderTraversal(TreeNode root, List list){
if(root == null) return;
list.add(root.val);
preorderTraversal(root.left, list);
preorderTraversal(root.right, list);
}
}
비귀속판/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Preorder in ArrayList which contains node values.
*/
public List preorderTraversal(TreeNode root) {
List list = new ArrayList<>();
Stack stack = new Stack<>();
if(root == null) return list;
stack.push(root);
while(!stack.empty()){
TreeNode node = stack.pop();
list.add(node.val);
// left
if(node.right != null){
stack.push(node.right);
}
// right
if(node.left != null){
stack.push(node.left);
}
}
return list;
}
}
중순으로 두루 다니다.
귀속판/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Inorder in ArrayList which contains node values.
*/
List list = new ArrayList<>();
public List inorderTraversal(TreeNode root) {
if(root == null) return list;
inorderTraversal(root.left);
list.add(root.val);
inorderTraversal(root.right);
return list;
}
}
비귀속판/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Inorder in ArrayList which contains node values.
*/
//
public List inorderTraversal(TreeNode root) {
Stack stack = new Stack<>();
List list = new ArrayList<>();
if(root == null) return list;
while(root != null){
stack.push(root);
root = root.left;
}
while(!stack.empty()){
TreeNode node = stack.peek();
list.add(node.val);
if(node.right == null){
node = stack.pop();
while(!stack.empty() && stack.peek().right == node){
node = stack.pop();
}
}
else{
node = node.right;
while(node != null){
stack.push(node);
node = node.left;
}
}
}
return list;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Cognos 목록을 프롬프트에서 선택한 항목으로 오름차순 및 내림차순으로 정렬
Cognos BI & Analytics에서 리스트의 정렬을 항목 지정 및 정렬 순서 지정으로 하고 싶을 때의 방법입니다.
정렬 항목 프롬프트에서 수량을 선택하고 정렬 순서 프롬프트에서 내림차순을 선택한 예입니다.
정...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.
/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Preorder in ArrayList which contains node values.
*/
public List preorderTraversal(TreeNode root) {
List list = new ArrayList<>();
preorderTraversal(root, list);
return list;
}
public void preorderTraversal(TreeNode root, List list){
if(root == null) return;
list.add(root.val);
preorderTraversal(root.left, list);
preorderTraversal(root.right, list);
}
}
/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Preorder in ArrayList which contains node values.
*/
public List preorderTraversal(TreeNode root) {
List list = new ArrayList<>();
Stack stack = new Stack<>();
if(root == null) return list;
stack.push(root);
while(!stack.empty()){
TreeNode node = stack.pop();
list.add(node.val);
// left
if(node.right != null){
stack.push(node.right);
}
// right
if(node.left != null){
stack.push(node.left);
}
}
return list;
}
}
귀속판
/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Inorder in ArrayList which contains node values.
*/
List list = new ArrayList<>();
public List inorderTraversal(TreeNode root) {
if(root == null) return list;
inorderTraversal(root.left);
list.add(root.val);
inorderTraversal(root.right);
return list;
}
}
비귀속판
/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
/**
* @param root: A Tree
* @return: Inorder in ArrayList which contains node values.
*/
//
public List inorderTraversal(TreeNode root) {
Stack stack = new Stack<>();
List list = new ArrayList<>();
if(root == null) return list;
while(root != null){
stack.push(root);
root = root.left;
}
while(!stack.empty()){
TreeNode node = stack.peek();
list.add(node.val);
if(node.right == null){
node = stack.pop();
while(!stack.empty() && stack.peek().right == node){
node = stack.pop();
}
}
else{
node = node.right;
while(node != null){
stack.push(node);
node = node.left;
}
}
}
return list;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Cognos 목록을 프롬프트에서 선택한 항목으로 오름차순 및 내림차순으로 정렬Cognos BI & Analytics에서 리스트의 정렬을 항목 지정 및 정렬 순서 지정으로 하고 싶을 때의 방법입니다. 정렬 항목 프롬프트에서 수량을 선택하고 정렬 순서 프롬프트에서 내림차순을 선택한 예입니다. 정...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.