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

力扣(leetcode)每日一题 3191 使二进制数组全部等于 1 的最少操作次数 I |贪心

3191. 使二进制数组全部等于 1 的最少操作次数 I

题干

给你一个二进制数组 nums

你可以对数组执行以下操作 任意 次(也可以 0 次):

  • 选择数组中 任意连续 3 个元素,并将它们 全部反转

反转 一个元素指的是将它的值从 0 变 1 ,或者从 1 变 0 。

请你返回将 nums 中所有元素变为 1 的 最少 操作次数。如果无法全部变成 1 ,返回 -1 。

示例 1:

**输入:**nums = [0,1,1,1,0,0]

**输出:**3

解释:
我们可以执行以下操作:

  • 选择下标为 0 ,1 和 2 的元素并反转,得到 nums = [**1**,**0**,**0**,1,0,0]
  • 选择下标为 1 ,2 和 3 的元素并反转,得到 nums = [1,**1**,**1**,**0**,0,0]
  • 选择下标为 3 ,4 和 5 的元素并反转,得到 nums = [1,1,1,**1**,**1**,**1**]
题解
public static int minOperations(int[] nums) {  
    int res = 0;  
    for (int i = 0; i < nums.length - 2; i++) {  
        if ((nums[i] & 1) == 0) {  
            res++;  
            nums[i] = 1;  
            if ((nums[i + 1] & 1) == 0) {  
                nums[i + 1] = 1;  
            } else {  
                nums[i + 1] = 0;  
            }  
            if ((nums[i + 2] & 1) == 0) {  
                nums[i + 2] = 1;  
            } else {  
                nums[i + 2] = 0;  
            }  
        } // 说明是1 跳过  
    }  
    if ((nums[nums.length - 1] & 1) == 1 && (nums[nums.length - 2] & 1) == 1) {  
        return res;  
    }  
    return -1;  
}
总结

这个写法是猜的。虽然不知道为什么,但是肯定当前为0的时候进行翻转的贪心策略最终肯定是翻转次数最少的。背后的数学原理我也不懂,但是可以猜测和尝试。

1改成0,0改成1 ,可以使用1-x表达式来获取


http://www.kler.cn/news/360845.html

相关文章:

  • iOS GCD的基本使用
  • 平衡二叉树最全代码
  • pdf怎么合并在一起?pdf合并的简单方法
  • Vue事件处理
  • Neo4J的APOC插件安装与配置
  • pikachu靶场CSRF-get测试报告
  • 八股面试2(自用)
  • http作业
  • Python(numpy库常见函数)
  • Java框架之MyBatis Plus
  • 贵州师范大学2025考研初复试资料清单一览
  • PLL锁相环带宽定义,以及PI参数自动整定
  • 使用SpringBoot自定义注解+AOP+redisson锁来实现防接口幂等性重复提交
  • 加密,混淆,摘要,序列化的理解
  • 柔性数组的使用
  • 基于ECS和NAS搭建个人网盘
  • Java访问修饰符private,default,protected,public
  • LeetCode_2413. 最小偶倍数_java
  • 基于Multisim的任意进制计数器设计与仿真
  • 【Linux 从基础到进阶】磁盘I/O性能调优