码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leetcode 665. Non-decreasing Array 非递减数列(中等)


    一、题目大意

    标签: 贪心

    https://leetcode.cn/problems/non-decreasing-array

    给你一个长度为 n 的整数数组 nums ,请你判断在 最多 改变 1 个元素的情况下,该数组能否变成一个非递减数列。

    我们是这样定义一个非递减数列的: 对于数组中任意的 i (0 <= i <= n-2),总满足 nums[i] <= nums[i + 1]。

    示例 1:

    输入: nums = [4,2,3]
    输出: true
    解释: 你可以通过把第一个 4 变成 1 来使得它成为一个非递减数列。

    示例 2:

    输入: nums = [4,2,1]
    输出: false
    解释: 你不能在只改变一个元素的情况下将其变为非递减数列。

    提示:

    • n == nums.length
    • 1 <= n <= 104
    • -105 <= nums[i] <= 105

    二、解题思路

    最多只有一次修改某个数字的机会,问能否将数组变为非递减数组。举例

    例1:4,** 2**, 3

    例2:-1, 4, 2, 3

    例3:2, 3, 3,** 2**, 4
    当后面的数字小于前面的数字后,例如例1中的2小于4,这时可以将修改前面的数字将4修改为2或修改后面的数字将2改为4。我们需要找到这个规律,判断修改哪个数字其实跟再前面的一个数大小有关系:

    如果再前面的数不存在,例1中,4前面没有数字了我们直接修改前面的数字为当前数字2即可;

    如果再前面的数字存在,并且小于当前数字时,例2中,我们需要修改前面的数字4为当前数字2;

    如果再前面的数字存在,且大于当前数,例3中,我们需要修改当前数字2为前面的数3。

    由于只有一次修改的机会,所以用一个变量cnt,初始化为1,修改数字后cnt自减1,当下次再需要修改时,如果cnt为0,直接返回false。遍历结束后返回true。

    三、解题方法

    3.1 Java实现

    public class Solution {
        public boolean checkPossibility(int[] nums) {
            int cnt = 1;
            for (int i = 1; i < nums.length; i++) {
                if (nums[i] < nums[i - 1]) {
                    if (cnt == 0) {
                        return false;
                    }
                    cnt--;
                    if (i == 1) {
                        nums[i - 1] = nums[i];
                    } else if (nums[i] >= nums[i - 2]) {
                        nums[i - 1] = nums[i];
                    } else {
                        nums[i] = nums[i - 1];
                    }
                }
            }
            return true;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    四、总结小记

    • 2022/7/31 今天天气很闷热呀
  • 相关阅读:
    Keras Sequential 模型
    OpenAI发布ChatGPT:程序员瞬间不淡定了
    机器学习——支持向量机(SVM)
    随机产生两个数在屏幕上打印,例如6*7=? 让学生输入答案,若正确打印答对了,否则提示学生重做,直到答对为止(小游戏)
    14:00面试,14:06就出来了,问的问题有点变态。。。
    Elasticsearch备份与还原:使用elasticdump
    美团一面:为什么线程崩溃崩溃不会导致 JVM 崩溃
    linux权限维持(二)
    基础操作:拓扑连线以及矩形文字位置
    Scratch可以参加的编程比赛大全
  • 原文地址:https://blog.csdn.net/ln_ydc/article/details/126088477
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号