码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [LeetCode]1413. 逐步求和得到正数的最小值


    1413. 逐步求和得到正数的最小值

    题目

    
    给你一个整数数组 nums 。你可以选定任意的 正数 startValue 作为初始值。
    
    你需要从左到右遍历 nums 数组,并将 startValue 依次累加上 nums 数组中的值。
    
    请你在确保累加和始终大于等于 1 的前提下,选出一个最小的 正数 作为 startValue 。
    
     
    
    示例 1:
    
    输入:nums = [-3,2,-3,4,2]
    输出:5
    解释:如果你选择 startValue = 4,在第三次累加时,和小于 1 。
                    累加求和
                    startValue = 4 | startValue = 5 | nums
                      (4 -3 ) = 1  | (5 -3 ) = 2    |  -3
                      (1 +2 ) = 3  | (2 +2 ) = 4    |   2
                      (3 -3 ) = 0  | (4 -3 ) = 1    |  -3
                      (0 +4 ) = 4  | (1 +4 ) = 5    |   4
                      (4 +2 ) = 6  | (5 +2 ) = 7    |   2
    示例 2:
    
    输入:nums = [1,2]
    输出:1
    解释:最小的 startValue 需要是正数。
    示例 3:
    
    输入:nums = [1,-2,-3]
    输出:5
     
    
    提示:
    
    1 <= nums.length <= 100
    -100 <= nums[i] <= 100
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    方法1:贪心

    //记录最小的累加和,最后满足 accSumMin + startValue >=1
    public int minStartValue(int[] nums) {
        int accSum = 0, accSumMin = 0;
        for (int x : nums) {
            accSum += x;
            accSumMin = Math.min(accSumMin, accSum);
        }
        return -accSumMin + 1;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    方法2:二分

            public int minStartValue(int[] nums) {
                int l = 1, r = 10010;
                while (l < r) {
                    int mid = l + (r - l) / 2;
                    if (valid(nums, mid)) r = mid;
                    else l = mid + 1;
                }
                return l;
            }
    
    
            private boolean valid(int[] nums, int startValue) {
                for (int x : nums) {
                    startValue += x;
                    if (startValue < 1) return false;
                }
                return true;
            }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

  • 相关阅读:
    JavaWeb环境配置 IDE2022版
    小明回家 题解 BFS
    6、Arrays类
    jetson xiaver NX 安装tensorflow object detection api 遇到的tensorflow-addons 不能安装问题
    数据库设计中如何选择主键 (字符串或数值数据类型 )| Part 2
    Qt 杂记
    基于Python的接口自动化-JSON模块的操作
    好用的工具
    如何使用Ruby 多线程爬取数据
    0-1背包-动态规划
  • 原文地址:https://blog.csdn.net/wat1r/article/details/126241603
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号