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

程序员知识网站需要多少钱wordpress页面导航

程序员知识网站需要多少钱,wordpress页面导航,wordpress用户,赤峰建设银行网站Every day a Leetcode 题目来源:2086. 从房屋收集雨水需要的最少水桶数 解法1:贪心 我们可以对字符串 hamsters 从左到右进行一次遍历。 每当我们遍历到一个房屋时,我们可以有如下的选择: 如果房屋的两侧已经有水桶&#xff…

Every day a Leetcode

题目来源:2086. 从房屋收集雨水需要的最少水桶数

解法1:贪心

我们可以对字符串 hamsters 从左到右进行一次遍历。

每当我们遍历到一个房屋时,我们可以有如下的选择:

  • 如果房屋的两侧已经有水桶,那么我们无需再放置水桶了;

  • 如果房屋的两侧没有水桶,那么我们优先在房屋的「右侧」放置水桶,这是因为我们是从左到右进行遍历的,即当我们遍历到第 i 个位置时,前 i−1 个位置的房屋周围都是有水桶的。因此我们在左侧放置水桶没有任何意义,而在右侧放置水桶可以让之后的房屋使用该水桶。

  • 如果房屋的右侧无法放置水桶(例如是另一栋房屋或者边界),那么我们只能在左侧放置水桶。如果左侧也不能放置,说明无解。

我们可以通过修改字符串来表示水桶的放置,从而实现上述算法。一种无需修改字符串的方法是,每当我们在房屋的右侧放置水桶时,可以直接「跳过」后续的两个位置,因为如果字符串形如 H.H,我们在第一栋房屋的右侧(即两栋房屋的中间)放置水桶后,就无需考虑第二栋房屋;如果字符串形如 H…,后续没有房屋,我们也可以全部跳过。

代码:

/** @lc app=leetcode.cn id=2086 lang=cpp** [2086] 从房屋收集雨水需要的最少水桶数*/// @lc code=start
class Solution
{
public:int minimumBuckets(string hamsters){int n = hamsters.size();int bucket = 0;for (int i = 0; i < n; i++){if (hamsters[i] == 'H'){if (i + 1 < n && hamsters[i + 1] == '.'){bucket++;i += 2;}else if (i - 1 >= 0 && hamsters[i - 1] == '.')bucket++;elsereturn -1;}}return bucket;}
};
// @lc code=end

结果:

复杂度分析:

时间复杂度:O(n),其中 n 是字符串 hamsters 的长度。

空间复杂度:O(1)。

解法2:动态规划

设遍历至前 i 个字符满足条件的最小水桶数为 dp[i]。

若 street[i - 1] 为 ‘.’:

  • 不放置水桶。此时有
  • 若前面一个为房屋(street[i - 2] == ‘H’),可放置水桶。此时有

else if street[i - 1] 为 ‘H’:

  • 前方必须放置水桶,则必须满足 street[i - 2] == ‘.’。此时有
  • 上一个条件满足情况下如果水桶前方是房子(street[i - 3] == ‘H’),则这个水桶也可以接到前面房子的水。此时有

所有的状态转移取最小值即可。

代码:

/** @lc app=leetcode.cn id=2086 lang=cpp** [2086] 从房屋收集雨水需要的最少水桶数*/// @lc code=start// 贪心// class Solution
// {
// public:
//     int minimumBuckets(string hamsters)
//     {
//         int n = hamsters.size();
//         int bucket = 0;
//         for (int i = 0; i < n; i++)
//         {
//             if (hamsters[i] == 'H')
//             {
//                 if (i + 1 < n && hamsters[i + 1] == '.')
//                 {
//                     bucket++;
//                     i += 2;
//                 }
//                 else if (i - 1 >= 0 && hamsters[i - 1] == '.')
//                     bucket++;
//                 else
//                     return -1;
//             }
//         }
//         return bucket;
//     }
// };class Solution
{
private:
#define INF 0x3F3F3F3F
#define MAX_LEN 1e5 + 10public:int minimumBuckets(string street){int n = street.size();vector<int> dp(MAX_LEN, INF);// 初始化dp[0] = 0;// 状态转移for (int i = 1; i <= n; i++){if (street[i - 1] == '.'){dp[i] = dp[i - 1];if (i - 2 >= 0 && street[i - 2] == 'H')dp[i] = min(dp[i], dp[i - 2] + 1);}else if (street[i - 1] == 'H'){if (i - 2 >= 0 && street[i - 2] == '.'){dp[i] = dp[i - 2] + 1;if (i - 3 >= 0 && street[i - 3] == 'H'){dp[i] = min(dp[i], dp[i - 3] + 1);}}}}return dp[n] >= INF ? -1 : dp[n];}
};
// @lc code=end

结果:

在这里插入图片描述

复杂度分析:

时间复杂度:O(n),其中 n 是字符串 street 的长度。

空间复杂度:O(MAX_LEN)。状态数组开销,MAX_LEN = 1e5 + 10。

http://www.yayakq.cn/news/196071/

相关文章:

  • 广州pc网站建设wordpress扒主题代码
  • 如何在外管局网站上做a合同wordpress本地怎么上传服务器
  • 学院评估 网站建设整改wordpress 和 shopify
  • 网站开发需要用到哪些设备长沙seo网络营销推广
  • 网站开发课程培训设计说明书怎么写
  • 推广型的网站怎么做厦门住房和城乡建设局
  • 设计公司企业网站详情免费发布信息的网站平台有哪些
  • 微信一键登录网站怎么做搭建平台网站有什么用
  • 物流跟踪网站建设免费好玩的网页游戏
  • 广州最好的网站设计wordpress作企业网站好吗
  • 湛江免费建站哪里有企业建设网站的比例
  • 用美图秀秀做网站图片张家界做网站的人
  • 宁波网站建设主页手机站
  • 什么是网站运营pc站转换手机网站
  • 南京建设工程质量监督站网站网站空间信息查询
  • 网站建设及推广好做吗石家庄建设网站哪家好
  • 竞彩网站开发上海网站搜索排名
  • 网站底版照片怎么做网络营销渠道的优势
  • 云南公司建网站多少钱有哪些做调查问卷赚钱的网站
  • 桂林北站改造网站建设公司推广方式
  • 运动猿app 网站开发邢台立享网络
  • 速成网站怎么做廊坊360推广方案
  • 做网站谁家好做设计常用的素材网站
  • 第一模板网站开发公司交房前财务交付风险
  • 陵水专业网站建设咸阳公司网站建设
  • 模板网站有什么不好上海高端网站设计公司
  • 开发网站监控推荐php网站开发报告书
  • 苏州网站建设布局桂林网站建设服务
  • 拓之朴 做网站多少钱动感十足的网站
  • 平湖公司做网站无锡企业网站