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

【力扣LeetCode】 1413_逐步求和得到正数的最小值

- 第 130 篇 -
Date: 2025 - 09 - 23
Author: 郑龙浩(仟墨)

文章目录

  • 【力扣LeetCode】 1413_逐步求和得到正数的最小值
  • 题目描述
  • 题目分析|思路解析
  • 代码

【力扣LeetCode】 1413_逐步求和得到正数的最小值

题目描述

给你一个整数数组 nums 。你可以选定任意的 正数 startValue 作为初始值。
你需要从左到右遍历 nums 数组,并将 startValue 依次累加上 nums 数组中的值。
请你在确保累加和始终大于等于 1 的前提下,选出一个最小的 正数 作为 startValue 。

题目分析|思路解析

题目说成人话就是:
要找一个最小的正数 startValue,使得这个数加上数组中的每一个前缀和都>=1。
如果是这样的话,也就意味着,只要加最小的前缀和=1,其他更大的前缀和必然也可以
公式就是:startValue + 最小的前缀和 = 1,最小的前缀和与1,最小前缀和与1是可知的,startValue是未知的,所以整理可得公式:1 - 最小的前缀和 => startValue

所以大概步骤就是:

  1. 算出所有的前缀和,在计算过程中求得最小的前缀和是多少
  2. 然后1 - 最小前缀和就得出了startValue
    我刚开始就没注意下面的点,导致结果是<1的时候返回了,此状况,应该返回1才正确。
    注意:求得startValue必须是>=1,所以如果结果是<1的,也只能返回1

代码

// 1413_逐步求和得到正数的最小值
// Author: 郑龙浩 Date: 2025年09月21日
// 用时:42min// 思路:
// 题目说成人话就是:
// 要找一个最小的正数 startValue,使得这个数加上数组中的每一个前缀和都>=1。
// 如果是这样的话,也就意味着,只要加最小的前缀和=1,其他更大的前缀和必然也可以
// 公式就是:startValue + 最小的前缀和 = 1,最小的前缀和与1,最小前缀和与1是可知的,startValue是未知的,所以整理可得公式:
// 1 - 最小的前缀和 => startValue// 所以大概步骤就是:
// 1 算出所有的前缀和,在计算过程中求得最小的前缀和是多少
// 2 然后1 - 最小前缀和就得出了startValue
// 我刚开始就没注意下面的点,导致结果是<1的时候返回了,此状况,应该返回1才正确。
// 注意:求得startValue必须是>=1,所以如果结果是<1的,也只能返回1
#include "bits/stdc++.h"
using namespace std;
class Solution {
public:int minStartValue(vector<int>& nums) {int len = nums.size();int min_sum = nums[0], sum = nums[0];for (int i = 1; i < len; i++) {sum += nums[i];if (min_sum > sum) min_sum = sum;}int startValue = 1 - min_sum; // 注意:求得startValue必须是>=1,所以如果结果是<1的,也只能返回1if (startValue < 1) return 1;else return startValue;}
};int main(void) {ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);// vector <int> nums = {-3, 2, -3, 4, 2};vector <int> nums = {1, 2};// vector <int> nums = {1, -2, -3};Solution sol;cout << sol.minStartValue(nums);return 0;
}
http://www.dtcms.com/a/398490.html

相关文章:

  • 给别人做网站赚钱吗wordpress邮件找客户端
  • 有没有做logo的网站网站开发常去的论坛
  • todesk连接Mac设备时卡在100%(手机、平板连接时卡在75%)
  • ETF网格策略的呼吸机制基于市场热度的动态间距调控
  • 高性能服务器配置经验指南7——基于tar命令打包存储conda虚拟环境
  • C++ constexpr 修饰符与函数
  • Conda虚拟环境管理完全指南:从创建到跨设备迁移
  • SuperScript:C#脚本编辑器、C#脚本引擎
  • 网站建设项目设计的图片青岛seo服务哪家好
  • 打开网站代码怎么写深圳十大建筑设计院
  • 网站如何制作 优帮云关于学校网站建设的请示
  • 网络协议与层次划分
  • Express入门和实践(一)
  • 从零开始搭建深度学习大厦系列-4.Transformer生成式大语言模型
  • 【MySQL初阶】04-数据表的操作
  • 展会进行时 | Splashtop Inc.(浪桥科技)亮相2025中国国际工业博览会
  • SMTPman,smtp服务器的使用全解析与指南!
  • 39.应用层HTTP协议(二)
  • 网站调用微信js视频深圳微信网站建设公司哪家好
  • 佛山网站建设策划做网站需提供什么资料
  • Swift 实现 DLNA 投屏功能:完整技术解析与实践指南
  • Axios 请求
  • Macbook突然无法开机和充电导致项目无法编译-《时光小铺》的开发意外事故~另寻求维修高手指导
  • 用html5写一个宠物小精灵游戏
  • 客观与主观评估扩散模型在构音障碍语音增强中的应用
  • Xcode 26 error
  • python+django/flask的宠物救助及领养系统javaweb
  • 半导体网站建设装饰公司网页设计
  • 企业网站建设策划书 前言做影视网站需要多大硬盘
  • 电子基石:硬件工程师的器件手册 (十六) - 射频电路:电磁波的有意操控