当前位置: 首页 > article >正文

【数据结构与算法 | 灵神题单 | 二叉搜索树篇】力扣653

1. 力扣653:两数之和IV - 输入二叉搜索树

1.1 题目:

给定一个二叉搜索树 root 和一个目标结果 k,如果二叉搜索树中存在两个元素且它们的和等于给定的目标结果,则返回 true

示例 1:

输入: root = [5,3,6,2,4,null,7], k = 9
输出: true

示例 2:

输入: root = [5,3,6,2,4,null,7], k = 28
输出: false

提示:

  • 二叉树的节点个数的范围是  [1, 104].
  • -104 <= Node.val <= 104
  • 题目数据保证,输入的 root 是一棵 有效 的二叉搜索树
  • -105 <= k <= 105

1.2 思路:

用哈希表存储遍历过的元素,如果在哈希表中找到了自己的另一半,返回true,否则继续查找。

1.3 题解:

class Solution {
    // 使用哈希表
    HashSet<Integer> hashset = new HashSet<>();
    boolean flag = false;
    public boolean findTarget(TreeNode root, int k) {
        dfs(root, k);
        return flag;
    }
    //dfs的遍历顺序其实不重要
    private void dfs(TreeNode node, int k) {
        if(node == null) return;

        dfs(node.left, k);
        // 如果在哈希表中没找到另一个加起来等于k的元素
        // 就把该节点值加入到哈希表中
        // 继续判断后续节点的值
        
        // 如果找到了,由题意,返回true
        if(!hashset.contains(k - node.val)){
            hashset.add(node.val);
        }else{
            flag = true;
            return;
        }

        dfs(node.right, k);
    }
}


http://www.kler.cn/a/315410.html

相关文章:

  • WLAN消失或者已连接但是访问不了互联网
  • 传奇996_21——龙岭事件
  • 基于Java Web的传智播客crm企业管理系统的设计与实现
  • 【MySQL 保姆级教学】事务的隔离级别(详细)--下(13)
  • Vector Optimization – Stride
  • 结构体(c语言)
  • 基于SpringBoot的在线点餐系统【附源码】
  • 【C++笔记】C++编译器拷贝优化和内存管理
  • 【Obsidian】当笔记接入AI,Copilot插件推荐
  • SpringCloud alibaba
  • 算法-环形链表(141)
  • 【Elasticsearch】-图片向量化存储
  • ffplay ubuntu24出现:Could not initialize SDL - dsp: No such audio device
  • Redis存储原理
  • ElementUI 用span-method实现循环el-table组件的合并行功能
  • Spring Boot文件上传/下载问题
  • 计算机网络(运输层)
  • Selenium:开源自动化测试框架的Java实战解析
  • SpringCloud Feign 以及 一个标准的微服务的制作
  • linux驱动开发-ioctl
  • 中国电子学会202406青少年软件编程(Python)等级考试试卷(四级)真题
  • 智能家政保洁|基于java和vue的智能家政保洁预约系统(源码+数据库+文档)
  • 【已解决】Linux ubuntu 20.04 docker 不需要sudo权限
  • openssl 生成多域名 多IP 的数字证书
  • 活动系统开发之采用设计模式与非设计模式的区别-后台功能总结
  • pytorch 算子调用kernel示例(MINIST)