wy的leetcode刷题记录_Day50

news2024/11/24 4:07:48

wy的leetcode刷题记录_Day50

声明

本文章的所有题目信息都来源于leetcode
如有侵权请联系我删掉!
时间:2022-11-23

前言


目录

  • wy的leetcode刷题记录_Day50
    • 声明
    • 前言
    • 1742. 盒子中小球的最大数量
      • 题目介绍
      • 思路
      • 代码
      • 收获
    • 700. 二叉搜索树中的搜索
      • 题目介绍
      • 思路
      • 代码
      • 收获

1742. 盒子中小球的最大数量

今天的每日一题是:1742. 盒子中小球的最大数量

题目介绍

你在一家生产小球的玩具厂工作,有 n 个小球,编号从 lowLimit 开始,到 highLimit 结束(包括 lowLimit 和 highLimit ,即 n == highLimit - lowLimit + 1)。另有无限数量的盒子,编号从 1 到 infinity 。

你的工作是将每个小球放入盒子中,其中盒子的编号应当等于小球编号上每位数字的和。例如,编号 321 的小球应当放入编号 3 + 2 + 1 = 6 的盒子,而编号 10 的小球应当放入编号 1 + 0 = 1 的盒子。

给你两个整数 lowLimit 和 highLimit ,返回放有最多小球的盒子中的小球数量。如果有多个盒子都满足放有最多小球,只需返回其中任一盒子的小球数量。

示例 1:
输入:lowLimit = 1, highLimit = 10
输出:2
解释: 盒子编号:1 2 3 4 5 6 7 8 9 10 11 … 小球数量:2 1 1 1 1 1 1 1 1 0 0 … 编号 1 的盒子放有最多小球,小球数量为 2 。

示例 2:
输入:lowLimit = 5, highLimit = 15
输出:2
解释: 盒子编号:1 2 3 4 5 6 7 8 910 11 … 小球数量:1 1 1 1 2 2 1 1 1 0 0 … 编号 5 和 6的盒子放有最多小球,每个盒子中的小球数量都是 2 。

思路

简单的模拟思路:创建一个辅助函数用来计算每个数字每个位数上的数字相加和,然后使用一个hash表来存贮对应下标箱子的存贮个数。最后在这个hash表中寻找最大值就可以了。

代码

class Solution {
public:
    int countBalls(int lowLimit, int highLimit) {
        unordered_map<int,int> hash;
        for(int i=lowLimit;i<=highLimit;i++)
        {
            int index=caculate_index(i);
            if(!hash.count(index))
                hash[index]=1;
            else
                hash[index]++;
        }
        int ans=hash[0];
        for(auto temp:hash)
        {
            ans=max(ans,temp.second);
        }
        return ans;
    }

    int caculate_index(int num)
    {
        int res=0;
        while(num!=0)
        {
            res+=num%10;
            num/=10;
        }
        return res;
    }
};

收获

简单模拟提,刷刷手速

700. 二叉搜索树中的搜索

700. 二叉搜索树中的搜索

题目介绍

给定二叉搜索树(BST)的根节点 root 和一个整数值 val。

你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 null 。

示例 1:
在这里插入图片描述
输入:root = [4,2,7,1,3], val = 2
输出:[2,1,3]

示例 2:
在这里插入图片描述
输入:root = [4,2,7,1,3], val = 5
输出:[]

思路

递归:
利用搜索树的性质,根节点左边的值小于根节点,右边的值大于根节点递归的搜索。
递推:
同理,只需沿着树的某一条路符合搜索树的性质走就可以了

代码

递归:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        if(root==nullptr)
            return root;
        TreeNode*ans;
        if(val>root->val)
            ans=searchBST(root->right,val);
        else if(val<root->val)
            ans=searchBST(root->left,val);
        else if(val==root->val)
            return root;
        return ans;
        
    }
};

递推:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        while(root!=nullptr)
        {
            if(val>root->val)
            {
                root=root->right;
            }
            else if(val<root->val)
            {
                root=root->left;
            }
            else if(val==root->val)
                return root;
        }
        return root;//这个时候就是没找到了
    }
};

收获

重新温故了二叉树的知识,二叉树的特点就是根节点左边的所有节点的值全部小于根节点的值,根节点右边的所有节点的值全部大于根节点的值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/43098.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Maven问题相关 1 存在jar 却无法映射

这是一个比较新手的问题了&#xff0c;可能刚接触这个问题的小伙伴会纳闷&#xff0c;我这个本地仓库明明有却怎么映射失败吗?不科学啊。尤其是面临公司项目很多依赖的情况下&#xff0c;会出现大量这种情况&#xff0c;就算是项目经理过来。也可能会卧槽&#xff0c;我电脑上…

基于python的CLI应用程序开发(第一节):简单了解一下Typer

Typer开发(第一节)&#xff1a;简单了解一下Typer 文章目录Typer开发(第一节)&#xff1a;简单了解一下Typer1. 简介2. 安装3. 在编辑器中使用Typer4. 简单应用15. 简单应用26. 命令参数7.其它1. 简介 Typer 是一个python用于构建 CLI 应用程序的库,简单说就是开发控制台程序&…

Idea+maven+spring-cloud项目搭建系列--8整合Zookeeper

本文为 Ideamavenspring-cloud项目搭建系列&#xff0c;maven项目的创建可以参考&#xff1a; https://blog.csdn.net/l123lgx/article/details/121467823 本文使用了nacos 作为微服务的注册与发现&#xff0c;nacos 阿里云服务器的安装可以参考&#xff1a;https://blog.csdn.…

构建用于签名/加密双证书测试体系的可执行命令

注意事项 生成证书请求的填写 范例Subject: C CN, ST Beijing, L Beijing, O MSI, OU msi, CN ca, emailAddress cagmssl.com 前面的步骤存在错误&#xff0c;后面改用脚本进行证书生成&#xff0c;阅读时请跳过前面错误的内容 错误的内容 -> 开始 CA 生成私钥 op…

了解mysql脏页落盘过程

脏页落盘 什么是脏页&#xff1f; 对数据的修改&#xff0c;首先改内存中的缓冲池的页&#xff0c;由于缓冲区的数据跟磁盘中的数据不一致&#xff0c;所以称缓冲区的页为脏页。 脏页如何写入到磁盘&#xff1f; 不是每次更新都触发脏页落盘&#xff0c;而是通过CheckPoint机…

计及调频成本和荷电状态恢复的多储能系统调频功率双层优化【蓄电池经济最优目标下充放电】(基于matlab+yalmip+cplex的蓄电池出力优化)

摘要&#xff1a;针对电网中不同类型储能电站调频成本、剩余调频 能力存在差异、储能电站内部储能单元 SOC 过高或过低 的问题&#xff0c;提出计及调频成本和 SOC 恢复的多储能系统调 频功率双层优化策略&#xff0c;该策略包含调频功率优化层和 SOC 优化层&#xff1a;在调频…

覆盖libc.so.6的惨痛教训

覆盖libc.so.6的惨痛教训背景问题原因解决1、当前session未断开2、OS崩溃重启&#xff0c;所有ssh session断开惨痛教训1、对于上产环境的内核依赖库文件不能随意覆盖、删除。2、 scp 文件覆盖问题总结参考背景 发生时间: 2022年11月28日08:55:20 偷了个懒&#xff0c;在安装t…

Allegro走线自动关闭其它飞线操作指导

Allegro走线自动关闭其它飞线操作指导 Allegro在走线时候有一个自动关闭其它网络飞线的功能,具体操作如下 点击add connect命令 在option里面选择Auto-blank other rats 未勾选的状态 勾选后的状态,其它网络的飞线都被关闭了 This section is describe what the functio…

楼盘vr虚拟样板间,为售楼中心带来财气

房企也进入业绩冲刺期。为了完成销售目标&#xff0c;扩大市场销售面积&#xff0c;各大房企必将加大楼盘推出&#xff0c;降价冲销量已成常态。虚拟样板间采用创意化的营销策略&#xff0c;在激烈的竞争中脱颖而出。 所谓的VR虚拟样板间就是&#xff0c;利用数字化技术把建成或…

使用AWS的API Gateway实现websocket

问题 最近业务上面需要使用到WebSocket长连接来解决某些业务场景。 一图胜千言 注意&#xff1a;这里承担WebSocket服务器的是AWS API Gateway&#xff1b;后面的EC2业务服务&#xff0c;其实都是REST接口服务。 这里主要关注API Gateway和REST业务服务怎么实现API Gateway要…

Mysql事务机制

目录 一&#xff1a;定义 二&#xff1a;事务的特质 三&#xff1a;检测ACID特性 1. 准备工作. 2. 测试原子性和持久性 case1&#xff1a; 模拟原子性的全部失败 case2&#xff1a;模拟原子性的全部成功 case3&#xff1a;检查 持久性。 3. 测试一致性 case1&#xff…

[附源码]计算机毕业设计springboot餐馆点餐管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

马尔可夫链

目录 1.相关概念 2.马尔可夫链的状态概率分布推演及稳态分布 3.马尔可夫链的应用 4.稳态分布性质 1.相关概念 小明同学每日选择早餐的概率转化如下图所示&#xff1a; 并且当日的选择只受前一日的结果以及对应的转移概率影响&#xff0c;与之前的选择无关。———> …

Spring Cloud Alibaba 容器化部署最佳实践 | 本地部署版本 | Seata服务端组件安装

Seata 是一款开源的分布式事务解决方案&#xff0c;致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式&#xff0c;为用户打造一站式的分布式解决方案。 下载地址 https://github.com/seata/seata/releases Seata安装-修改配…

PyQt5 信号(Signal)与槽(Slot)

PyQt5 信号与槽信号与槽介绍内置信号与槽的使用自定义信号与槽的使用自定义信号和内置槽函数自定义信号和自定义槽函数自定义有参信号使用自定义信号参数装饰器信号与槽信号与槽的断开和连接多线程中信号与槽的使用信号与槽介绍 信号(Signal)与槽(Slot)是Qt中的核心机制&#…

基于Spring Boot的个人博客系统(源码+数据库)

目录 一、系统功能框架图 二、开发技术 三、开发环境 四、页面展示 1.登录页面 2.首页 3.文章详情页面 4.文章评论页面 ​5.后台页面 6.后台文件编辑页面 ​7.后台文章管理列表页面 五、文件组织结构 六、数据库设计 1. 文章详情表t_article 2.文章评论表t_comm…

Elasticsearch:构建地图以按国家或地区比较指标

标如果你不熟悉 Elastic 地图&#xff0c;本教程是一个不错的起点。 它会指导你完成处理位置数据的常见步骤。在完成本教程后&#xff0c;你将学会: 创建具有多个图层和数据源的地图使用符号、颜色和标签来设置数据值的样式在仪表板中嵌入地图在仪表板中跨仪表盘搜索 完成本教…

【Scala专栏】数据类型、变量常量、类和对象

本文内容主要分为3节&#xff0c;依次讲解&#xff1a;Scala的数据类型有哪些&#xff1f; 变量常量如何使用&#xff1f; 类和对象如何理解&#xff1f; 受限于博主的大脑容量&#xff0c;大概是无法做到事无巨细的&#xff0c;不过其实也没必要那么"细"&#xff0c…

Java核心技术卷Ⅰ-第三章Java的基本程序设计结构

重点 1.数据类型 2.运算符 3.字符串 4.控制流程 5.数组 1.数据类型 整型&#xff1a;Java程序必须保证在所有机器上都能得到相同的运行结果&#xff0c;所以各种数据类型的取值范围是固定的&#xff1b;在C/C中&#xff0c;int和long类型的大小与目标平台相关 类型存储需求取值…

基于粒子群算法的线性规划问题求解matlab程序

基于粒子群算法的线性规划问题求解matlab程序 1 基本粒子群算法流程 粒子群算法基于“种群”和“进化”的概念&#xff0c;通过个体间的协作与竞争&#xff0c;实现复杂空间最优解的搜索&#xff0c;其流程如下&#xff1a; &#xff08;1&#xff09;初始化粒子群&#xff…