leetcode记录-605-种花问题-贪心

2024-01-08 15:48

本文主要是介绍leetcode记录-605-种花问题-贪心,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

605-种花问题

在这里插入图片描述

思路

  1. 自己的:
    寻找所有为1的下标,组成一个数组a。对该数组遍历,每两个之间的差-1即为0的个数,因为均非首尾,所以(差-1)/2-1即为可插的花数。对于首尾,数组第一个元素为第一个1的下标,其前面可插花数为a[0]/2,最后可插花数为(原数组长度-最后一个1的下标-1)/2。将计算的数加起来,如果大于等于n,则证明可以插n朵。——注意,不要忘记全0的情况。
  2. 别人的题解(双重更优:一次遍历+到n朵插进去就停止,不做无用功):
    跳格子:i从头开始跳,i遇到0时【如果后面i+1是1,则i+1后面的后面才可能插,跳到i+3;如果后面i+1是0,则i插一朵n-1,跳到i+2(因为这里插了一朵,后面的肯定不能插了,就看下下一个能不能插)】,i遇到1时【后面不能插,跳到i+2判断能不能插】,当n到0(准备的花都插完)或者i=坑的length时(无坑可插),结束遍历。

代码

  1. 自己的:
class Solution {public boolean canPlaceFlowers(int[] flowerbed, int n) {int[] a = new int[flowerbed.length];int index=0;for (int i = 0; i < flowerbed.length; i++) {if (flowerbed[i]==1){a[index]=i;index++;}}int num=0;if (index>0){for (int i = 0; i < index-1; i++) {int temp = a[i+1]-a[i]-1; //中间几个0if(temp>1) {num+=(a[i+1]-a[i])/2-1;}}int end = flowerbed.length-a[index-1]-1;num=num+a[0]/2+end/2;}else {int end = flowerbed.length+1;num = end/2;}//从第一个1开始,看他和后面的一个1差几个0,然后判断if (n<=num) return true;else return false;}
}
  1. 别人的思路写的:
class Solution {public boolean canPlaceFlowers(int[] flowerbed, int n) {for (int i = 0; i < flowerbed.length && n>0; ) {if (flowerbed[i]==1){//当前为1i=i+2;}else if(i==flowerbed.length-1||flowerbed[i+1]==0){//0后面为0或者这个0在末尾n--;i+=2;}else  //0后面为1i=i+3;}if (n>0) return false;else return true;}
}

技巧

  1. 当循环不同条件步进不同时,for循环不要写第三个部分,空着,但是要记得循环体每种情况都要有对i的操作或者break,否则可能一直循环。
  2. 思考用例条件时不要忘记特殊情况(此题全0数组)。

这篇关于leetcode记录-605-种花问题-贪心的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

解决RocketMQ的幂等性问题

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

深度解析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) 字段级别约束

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时我们针对

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map