https://leetcode-cn.com/problems/two-sum-iv-input-is-a-bst/
给定一个二叉搜索树和一个目标结果,如果 BST 中存在两个元素且它们的和等于给定的目标结果,则返回 true。
案例 1:
输入:
5
/ \
3 6
/ \ \
2 4 7
Target = 9
输出: True
案例 2:
输入:
5
/ \
3 6
/ \ \
2 4 7
Target = 28
输出: False
思路:先用中序遍历求出二叉树的节点值,再从中找出是否有满足条件的解
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
import java.util.*;
class Solution {
//定义一个动态数组存放中序遍历的结果
List<Integer> list=new ArrayList<Integer>();
public boolean findTarget(TreeNode root, int k) {
//中序遍历
BST(root,list);
int left=0,right=list.size()-1;
while(left<right){
if(list.get(left)+list.get(right)>k){
right--;
}
else if(list.get(left)+list.get(right)<k){
left++;
}
else{
return true;
}
}
return false;
}
public void BST(TreeNode root,List<Integer> list){
if(root==null){
return;
}
//先遍历左子树
BST(root.left,list);
//根节点
list.add(root.val);
//右子树
BST(root.right,list);
return;
}
}