LeetCode 605. 种花问题

这篇博客探讨了LeetCode中的605题——种花问题,分析了如何在不违反相邻花朵不能种植的规则下,确定能否种植n朵花。作者提出了在数组两端补充0的个人思路,以及官方推荐的贪心算法解决方案,该算法在遍历过程中一旦达到n朵花即可返回true,避免了不必要的计算。博客还提到了一种简化思路,仅通过判断后续位置是否已种花来解决问题。
摘要由CSDN通过智能技术生成

605. 种花问题

题目:假设有一个很长的花坛,一部分地块种植了花,另一部分却没有。可是,花不能种植在相邻的地块上,它们会争夺水源,两者都会死去。
给你一个整数数组 flowerbed 表示花坛,由若干 0 和 1 组成,其中 0 表示没种植花,1 表示种植了花。另有一个数 n ,能否在不打破种植规则的情况下种入 n 朵花?能则返回 true ,不能则返回 false。
链接 https://leetcode.cn/problems/can-place-flowers

个人思路

当数组长度大于等于3时,我们可以判断当连续存在3个0时,我们可以在中间的0上种上花朵,因为数组小于3时不好判断,所以为了代码流程的统一,可以在数组最左边、数组最右边分别补1个0,意味着花坛左边、右边没有花。

class Solution:
    def canPlaceFlowers(self, flowerbed: List[int], n: int) -> bool:
        flowerbed = [0] + flowerbed + [0]
        plant = 0
        i = 0
        while i < len(flowerbed)-2:
            if flowerbed[i] == flowerbed[i+1] == flowerbed[i+2]==0:
                plant += 1
                i = i + 2
            else:
                i = i + 1
            if plant >= n:
                return Tru
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值