【C++贪心】2086. 喂食仓鼠的最小食物桶数|1622

devtools/2024/10/17 16:04:13/

本文涉及知识点

C++贪心

LeetCode2086. 喂食仓鼠最小食物

给你一个下标从 0 开始的字符串 hamsters ,其中 hamsters[i] 要么是:
‘H’ 表示有一个仓鼠在下标 i ,或者’.’ 表示下标 i 是空的。
你将要在空的位置上添加一定数量的食物来喂养仓鼠。如果仓鼠的左边或右边至少有一个食物,就可以喂食它。更正式地说,如果你在位置 i - 1 或者 i + 1 放置一个食物,就可以喂养位置为 i 处的仓鼠
在 空的位置 放置食物以喂养所有仓鼠的前提下,请你返回需要的 最少 食物数。如果无解请返回 -1 。
示例 1:
在这里插入图片描述

输入:hamsters = “H…H”
输出:2
解释:
我们可以在下标为 1 和 2 处放食物
可以发现如果我们只放置 1 个食物,其中一只仓鼠将得不到喂养。
示例 2:

在这里插入图片描述

输入:street = “.H.H.”
输出:1
解释:
我们可以在下标为 2 处放置一个食物
示例 3:

输入:street = “.HHH.”
输出:-1
解释:
如果我们如图那样在每个空位放置食物,下标 2 处的仓鼠将吃不到食物。
提示:
1 <= hamsters.length <= 105
hamsters[i] 要么是 ‘H’ ,要么是 ‘.’ 。

C++贪心

对于最左边的仓鼠,左边和右边一定要放食物。右边放食物不劣于左边,右边的食物可能共用,左边的一定不能共用。处理完最左的仓鼠后,移除最左的仓鼠。问题由f(n)变成f(n-1)。
枚举仓鼠,忽略食物和空地。
如果左边有食物,处理结束。
如果右边有空位,则在右边放食物,处理结束。
如果有左边有空位,则在左边放食物,处理结束。
否则返回-1。
h[i]=‘x’,表示放食物。
避免处理边界问题,s的左右各加’.'。
统计x的数量。

不能前后加’.',加之前"H"无解,加之后有解“xHx"。

代码

核心代码

class Solution {public:int minimumBuckets(string hamsters) {for (int i = 0; i  < hamsters.length(); i++) {if ('H' != hamsters[i]) { continue; }if ((i > 0) && ('x' == hamsters[i - 1])) { continue; }if((i+1 < hamsters.length())&& ('x' == hamsters[i + 1])) { continue; }if ((i + 1 < hamsters.length()) && ('.' == hamsters[i + 1])) { hamsters[i + 1] = 'x'; continue; }if ((i > 0) && ('.' == hamsters[i - 1])) { hamsters[i - 1] = 'x'; continue; }return -1;}return count(hamsters.begin(), hamsters.end(), 'x');}};

单元测试

string hamsters;TEST_METHOD(TestMethod11){hamsters = "H..H";auto res = Solution().minimumBuckets(hamsters);AssertEx(2,res);}TEST_METHOD(TestMethod12){hamsters = ".H.H.";auto res = Solution().minimumBuckets(hamsters);AssertEx(1, res);}TEST_METHOD(TestMethod13){hamsters = ".HHH.";auto res = Solution().minimumBuckets(hamsters);AssertEx(-1, res);}TEST_METHOD(TestMethod14){hamsters = "H";auto res = Solution().minimumBuckets(hamsters);AssertEx(-1, res);}

扩展阅读

我想对大家说的话
工作中遇到的问题,可以按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
学习算法:按章节学习《喜缺全书算法册》,大量的题目和测试用例,打包下载。重视操作
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛
失败+反思=成功 成功+反思=成功

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771
如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。


http://www.ppmy.cn/devtools/126499.html

相关文章

基于Spring Boot的大创项目高效管理系统

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理大创管理系统的相关信息成为必然。开发合适…

性能工具之JMeter 通过Java API生成 BeanShell PreProcessor 脚本

文章目录 一、前言二、实现代码三、代码示例四、最后 一、前言 对于上一篇文章&#xff08;性能工具之 HAR 格式化转换JMeter JMX 脚本文件&#xff09;还是有点问题。大家在使用的情况需要注意。 如果多个接口相同 path 路径且不同参数进行查询如&#xff1a; 上面接口如果…

【linux009】文件操作命令篇 - touch 命令

文章目录 touch 命令1、基本用法2、常见选项3、举例4、注意事项 touch 命令 touch 是 Linux 系统中的一个常用命令&#xff0c;用于创建空文件或更新已有文件的时间戳。它既可以用来快速生成新文件&#xff0c;也可以用来修改文件的访问时间&#xff08;access time, atime&am…

【JVM】一文详解类加载器

文章目录 类加载器的概述类加载器的分类启动类加载器(Bootstrap ClassLoader )扩展类型加载器(ExClassLoader)系统类加载器(Application ClassLoader )总结 双亲委派机制概念双亲委派机制的优势 ClassLoaderfindClassdefineClassloadClass&#xff0c;findClass&#xff0c;def…

js 精确计算(加减乘除)

js 精确计算(加减乘除) 工具类CalcUtil.js class CalcUtil {// 两数相加calcAdd(num1, num2) {var r1, r2, m;try {r1 num1.toString().split(.)[1].length;} catch (e) {r1 0;}try {r2 num2.toString().split(.)[1].length;} catch (e) {r2 0;}m Math.pow(10, Math.max…

ESP32-C3实现非易失变量(Arduino IDE )

1效果 网页输入数据&#xff0c;串口打印数据。掉电后数据还在 2源码 #include <WiFi.h> // 包含WiFi库&#xff0c;用于处理WiFi连接 #include <WebServer.h> // 包含WebServer库&#xff0c;用于创建Web服务器 #include <Preferences.h> // 包含Prefere…

uni-app写的微信小程序如何体积太大如何处理

方法一&#xff1a;对主包进行分包处理&#xff0c;将使用url: /pages/components/equipment/equipment跳转页面的全部拆分为分包&#xff0c;如url: /pagesS/components/equipment/equipment 在pages.json中添加 "subPackages": [{ "root"…

TensorFlow 的核心概念

TensorFlow 是一个开源的机器学习框架&#xff0c;由 Google 开发和维护。它提供了一个强大的工具集&#xff0c;用于构建和训练各种机器学习模型。 TensorFlow 的核心概念是计算图&#xff08;Computational Graph&#xff09;。计算图由节点&#xff08;Nodes&#xff09;和…