LeetCode 605. 种花问题(简单模拟)——每日一题

2023-11-21 15:50

本文主要是介绍LeetCode 605. 种花问题(简单模拟)——每日一题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇博客:LeetCode 53. 最大子序和

 写在前面:大家好!我是AC-fun,我的昵称来自两个单词Acceptedfun。我是一个热爱ACM的蒟蒻。最近萌生了刷LeetCode的想法,所以我打算从LeetCode简单的题目开始做起,攻陷LeetCode。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正,感谢大家的不吝赐教。我的唯一博客更新地址是:https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油,冲鸭!
用知识改变命运,用知识成就未来!加油 (ง •̀o•́)ง (ง •̀o•́)ง

原题链接:LeetCode 605. 种花问题

文章目录

  • 题目信息
    • 题目描述
    • 示例 1
    • 示例 2
    • 注意
  • 题解
    • 解题思路
    • 解题代码
    • 优化思路
    • 优化解题代码

题目信息

题目描述

 假设你有一个很长的花坛,一部分地块种植了花,另一部分却没有。可是,花卉不能种植在相邻的地块上,它们会争夺水源,两者都会死去。

 给定一个花坛(表示为一个数组包含0和1,其中0表示没种植花,1表示种植了花),和一个数 n 。能否在不打破种植规则的情况下种入 n 朵花?能则返回 True,不能则返回 False

示例 1

输入: flowerbed = [1,0,0,0,1], n = 1
输出: True

示例 2

输入: flowerbed = [1,0,0,0,1], n = 2
输出: False

注意

  1. 数组内已种好的花不会违反种植规则。
  2. 输入的数组长度范围为 [1, 20000]。
  3. n 是非负整数,且不会超过输入数组的大小。

题解

解题思路

 首先我们要判断只有一个花盆的情况,因为在下方的注意中说明了 n 是非负整数,且不会超过输入数组的大小。所以先判断数组只有一位(即只有一个花盆)的情况下是否满足条件,如果花盆中没有种花,那么直接返回 true 即可(因为n最大为1,所以可以直接返回 true)。

 然后判断两个及以上花盆的情况,主要的思路是使用一个计数器 cnt 来统计最多可以种多少朵花,如果最后 cnt >= n 那么说明可以种的下:首先判断第一个和最后一个花盆是否满足条件,如果满足则从第三个花盆开始判断,每一次判断其前后以及当前的位置是否都没有种花,如果都没有,则cnt++ 然后使该位置的数值为 1,表示种上了花,然后继续进行统计,直到统计到倒数第二个。

解题代码

class Solution {
public:bool canPlaceFlowers(vector<int>& flowerbed, int n) {int cnt = 0;int len = flowerbed.size();if (len == 1 && flowerbed[0] == 0) return true;if (flowerbed[0] == 0 && flowerbed[1] == 0) {cnt++;flowerbed[0] = 1;}if (flowerbed[len - 1] == 0 && flowerbed[len - 2] == 0) {cnt++;flowerbed[len - 1] = 1;}for (int i = 2; i < flowerbed.size() - 1; i++) {if (flowerbed[i - 1] == 0 && flowerbed[i + 1] == 0 && flowerbed[i] != 1) {cnt++;flowerbed[i] = 1;}} if (cnt >= n) return true;return false;}
};

优化思路

 先在数组第一位之前和最后一位之后加上一个 0,然后就可以直接判断,而不需要特判是否只有一个花盆以及第一个和最后一个花盆是否满足条件了。

优化解题代码

class Solution {
public:bool canPlaceFlowers(vector<int>& flowerbed, int n) {int cnt = 0;flowerbed.insert(flowerbed.begin(), 0);flowerbed.insert(flowerbed.end(), 0);int len = flowerbed.size();for (int i = 1; i < len - 1; i++) {if (flowerbed[i - 1] == 0 && flowerbed[i + 1] == 0 && flowerbed[i] != 1) {cnt++;flowerbed[i] = 1;}} if (cnt >= n) return true;return false;}
};

未完待续,持续更新中……
在这里插入图片描述

这篇关于LeetCode 605. 种花问题(简单模拟)——每日一题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/403350

相关文章

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对