653.两数之和 IV - 输入 BST
给定一个二叉搜索树和一个目标结果,如果 BST 中存在两个元素且它们的和等于给定的目标结果,则返回 true。
案例 1:
输入:
5
/ \
3 6
/ \ \
2 4 7
Target = 9
输出: True
案例 2:
输入:
5
/ \
3 6
/ \ \
2 4 7
Target = 28
输出: False
分析: 先先序遍历树,将所有节点值放入数组,之后遍历数组查找是否有那两个值满足条件。要注意数组仅有一个数的情况,此时返回false。
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool findTarget(TreeNode* root, int k) {
if(root==NULL) return false;
vector<int> nums;
preord(root,nums);
int tmp=0;
if(nums.size()==1) return false;
for(int i=0;i<nums.size()-1;i++)
{
tmp=k-nums[i];
for(int j=i+1;j<nums.size();j++)
{
if(tmp==nums[j]) return true;
}
}
return false;
}
void preord(TreeNode* root,vector<int>& nums)
{
if(root==NULL) return;
nums.push_back(root->val);
preord(root->left,nums);
preord(root->right,nums);
return;
}
};