代码随想录算法训练营第34天 | 1005.K次取反后最大化的数组和 134.加油站 135.分发糖果

K次取反后最大化的数组和

Alt
贪心局部最优:将绝对值大的负数变为正数,当前和变为最大;全局最优:整体获得最大和。
如果负数都变成正数之后,k > 0,仍然需要继续翻转,贪心局部最优:将最小的正数翻转,当前和变为最大;全局最优:整体获得最大和。
按绝对值排序很重要!

class Solution{
static bool cmp(int a, int b){return abs(a) > abs(b);  // 要注意按绝对值排序,优先翻转绝对值大的负数,最终也可以形成大到小的正数序列
}
public:int largestSumAfterKNegations(vector<int>& nums, int k){sort(nums.begin(), nums.end(), cmp);for(int i = 0; i < nums.size(); i++){if(nums[i] < 0 && k > 0){nums[i] *= -1;  // 将负数翻转k--;}}if(k % 2)  nums[nums.size() - 1] *= -1;  // 如果仍然需要继续翻转,将最小正数翻转int result = 0;for(int i : nums)  result += i;return result;}
};

加油站

Alt
最好想的就是暴力求解,遍历每一个加油站作为起点,看能否找到合适的解。
方法一
先从下标0加油站出发。
情况1:gas总量比cost总量小,净消耗,肯定跑不到一圈
情况2:整个遍历过程中没出现过余量累加和小于0的情况,那么0就是起点
情况3:从后向前遍历,累加剩余油量,累加和能弥补从0出发的产生的最大亏空,那么从该节点就一定能回来,因为一定不会出现累加和小于0的情况了。

class Solution{
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost){int curSum = 0;int min = INT_MAX;for(int i = 0; i < gas.size(); i++){curSum += gas[i] - cost[i];if(min > curSum){min = curSum;}}if(curSum < 0)  return -1;if(min >= 0)  return 0;for(int i = gas.size() - 1; i > 0; i--){min += gas[i] - cost[i];if(min >= 0){return i;}}return -1;}
};

方法二:最好理解的贪心法
如果总耗油数目大于加油数目,那么不可能走完一圈。如下图所示,从下标0开始累加剩余量数组,和记为 curSum。一旦 curSum < 0,说明[0, i]区间内都没法作为起点走完一圈。继续从 i + 1 开始累计剩余油量数组,重复上述过程。
Alt
局部最优:余量 rest[i] 的累加和 curSum<0 时,起始位置至少在 i + 1。因为 i 之前的位置都一定不能跑完一圈。
全局最优:找到能跑一圈的起点。

class Solution{
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost){int curSum = 0;  // 维护当前的余量累计int totalSum = 0;  // 维护整个旅程的余量累计int start = 0;  // 维护起点for(int i = 0; i < gas.size(); i++){curSum += gas[i] - cost[i];totalSum += gas[i] - cost[i];  // 也可以在前面独立写一个for循环计算总余量然后判断,这里将两个for循环合为一个,写法上更简洁if(curSum < 0){curSum = 0;start = i + 1;}}if(totalSum < 0)  return -1;return start;}
};

分发糖果

Alt
双向的处理思想是关键,要同时考虑一个小孩的两侧并不容易。先保证右侧评分高的孩子会比左侧评分低的孩子得到更多的糖果,再去考虑另一侧,这样思路会清晰很多。
第一次遍历的局部最优:只要右边评分比左边大,右边的孩子就比左边多一个糖果;全局最优:评分高的右孩子比左侧孩子获得更多的糖果。(从前向后遍历)
第二次遍历要考虑左侧孩子评分比右侧高的情况。局部最优:只要左边评分比右边大,左边的孩子就比右侧多一个糖果;全局最优:评分高的左孩子比右侧孩子获得更多的糖果。(从后向前遍历)
取两次遍历的最大值,这样可以保证评分更高的孩子可以得到比相邻左孩子和右孩子都多的糖果。

class Solution{
public:int candy(vector<int>& ratings){vector<int> candyVec(ratings.size(), 1);for(int i = 1; i < ratings.size(); i++){if(ratings[i] > ratings[i - 1]){candyVec[i] = candyVec[i - 1] + 1;}}for(int i = ratings.size() - 2; i >= 0; i--){if(ratings[i] > ratings[i + 1]){candyVec[i] = max(candyVec[i], candyVec[i + 1] + 1);}}int result = 0;for(int i = 0; i < ratings.size(); i++){result += candyVec[i];}return result;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/654183.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

14.STM32F4 LCD屏幕概念及源码下载(LCD之一)

一、LCD液晶显示屏介绍 1、常见的显示设备 在目前市面上&#xff0c;常见的显示设备种类有&#xff1a;LED、显示数码管、点阵LED显示屏、LCD液晶显示屏&#xff0c;这几种设备的特点是&#xff1a; &#xff08;1&#xff09;LED LED灯是最简单的显示设备&#xff0c;它只有两…

SpringBoot 基础概念:注册BeanDefinition

SpringBoot 基础概念&#xff1a;注册BeanDefinition 1. 前言2. BeanDefinitionReaderUtils#registerBeanDefinition3. DefaultListableBeanFactory#registerBeanDefinition 1. 前言 问题&#xff1a;为什么需要注册BeanDefinition&#xff1f; 为了后续实例化。Spring架构是将…

Vue中虚拟Dom技术,你学会了吗?

​总的来说&#xff0c;虚拟DOM是Vue中一项关键的技术&#xff0c;通过优化DOM操作&#xff0c;提高了性能&#xff0c;同时使开发者更专注于数据的变化而不用过多关心底层DOM操作。 在Vue中&#xff0c;虚拟DOM&#xff08;Virtual DOM&#xff09;是一项关键的技术&#xff…

JavaWeb,ES6的学习

概述 ECMAScript 6&#xff0c;简称ES6&#xff0c;是JavaScript语言的一次重大更新。它于2015年发布&#xff0c;是原来的ECMAScript标准的第六个版本。ES6带来了大量的新特性&#xff0c;包括箭头函数、模板字符串、let和const关键字、解构、默认参数值、模块系统等等&#…

随便封装一下BaseActivity 之 二

接着上回&#xff0c;菊花也稍微封装一下 老规矩&#xff0c;上码 一、定义一个菊花interface&#xff0c;真正实现菊花的接口类 open interface ILoading {/*** 获取加载服务*/fun getLoad(): Any?/*** 注册目标view*/fun register(target: Any)/*** 注册目标view*/fun re…

天拓四方:物联网网关在机械制造企业的应用

随着物联网技术的不断发展&#xff0c;越来越多的机械制造企业开始探索如何利用物联网技术提升生产效率、降低运营成本。物联网网关作为物联网架构中的关键设备&#xff0c;能够实现设备间的数据交互与远程控制&#xff0c;为机械制造企业带来了巨大的商业价值。它能够实现设备…

负载均衡是什么,负载均衡有什么作用

一、什么是负载均衡 负载均衡是一种在计算机网络和系统架构中使用的技术&#xff0c;用于均衡分发工作负载到多个资源&#xff0c;比如&#xff1a;服务器、计算节点或存储设备上&#xff0c;以提高系统的性能、可伸缩性。 在传统的单个服务器架构中&#xff0c;当请求量增加…

leetcode-反转链表

206. 反转链表 题解&#xff1a; 定义两个指针prev和cur,分别指向当前节点的前一个节点和当前节点&#xff0c;初始时&#xff0c;prev为None&#xff0c;cur为head&#xff0c;在遍历的过程中&#xff0c;我们需要创建一个临时指针用来指向cur.next&#xff0c;因为cur指向p…

漏洞原理XSS存贮型漏洞

漏洞原理XSS存贮型漏洞 XSS&#xff08;跨站脚本攻击&#xff09;是一种常见的Web安全漏洞&#xff0c;它允许攻击者将恶意代码注入到网页中&#xff0c;进而攻击用户的浏览器。存储型XSS漏洞是一种特定类型的XSS漏洞&#xff0c;它发生在Web应用程序中&#xff0c;其中用户输入…

小红叒战小紫

概率dp #include <iostream> #include <string> #include <stack> #include <vector> #include <queue> #include <deque> #include <set> #include <map> #include <unordered_map> #include <unordered_set> #…

在租户内启用SharePoint Embedded

要开启 SharePoint Embedded&#xff0c;你得是管理员&#xff0c;然后按照这些步骤操作&#xff1a; 登录到你的 SharePoint 管理中心。在左边的菜单里找到“设置”选项&#xff0c;点进去。 3. 在设置页面里找到“SharePoint Embedded 应用”。 4.如果这个功能还没开启&…

Android Settings 显示电池点亮百分比

如题&#xff0c;Android 原生 Settings 里有个 电池电量百分比 的选项&#xff0c;打开后电池电量百分比会显示在状态栏。 基于 Android 13 &#xff0c; 代码在 ./packages/apps/Settings/src/com/android/settings/display/BatteryPercentagePreferenceController.java &am…

【flutter项目类型】project type如何区分

通过项目中.metadata内容区分 如 # Used by Flutter tool to assess capabilities and perform upgrades etc. # # This file should be version controlled and should not be manually edited.version:revision: 85684f9300908116a78138ea4c6036c35c9a1236channel: stablep…

【大数据】Flink 架构(二):数据传输

《Flink 架构》系列&#xff08;已完结&#xff09;&#xff0c;共包含以下 6 篇文章&#xff1a; Flink 架构&#xff08;一&#xff09;&#xff1a;系统架构Flink 架构&#xff08;二&#xff09;&#xff1a;数据传输Flink 架构&#xff08;三&#xff09;&#xff1a;事件…

(Aliexpress)速卖通卖家通过自养号补单提高出单率

在跨境电商领域&#xff0c;有些卖家可能会遇到这样的问题&#xff1a;自己的速卖通店铺始终没有订单产生。那么&#xff0c;当速卖通店铺一直不出单时&#xff0c;我们应该如何进行补救呢&#xff1f;今天珑哥将围绕这个问题展开探讨&#xff0c;并分享一些提升速卖通店铺销量…

HCIP复习课(mpls实验)

1、IP配置&#xff1a; R1&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a; R7&#xff1a; R8&#xff1a; 2、rip&#xff0c;ospf配置&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a…

信创联盟--朗思科技加入证券基金行业信息技术应用创新联盟,共促金融信创发展

近期&#xff0c;证券基金行业信息技术应用创新联盟&#xff08;以下简称&#xff1a;信创联盟&#xff09;新一批成员单位名单公布&#xff0c;朗思科技LanSive凭借产品创新以及实践案例成功入选&#xff0c;正式成为信创联盟成员单位。 信创联盟由上交所联合行业券商倡议发起…

Threejs 展示——fbx 格式模型导入

文章目录 需求分析 需求 导入fbx 格式的模型数据 分析 需要准备 fbx 格式的数据&#xff0c;如下所示 <template><div id"three-canvas" /> </template> <script> // import { Color, MOUSE, PerspectiveCamera, Scene, WebGLRenderer } …

【LLVM Pass解读】Reassociate 重结合优化

run函数的分析 首先&#xff0c;ReassociatePass是一个FunctionAnalysis&#xff0c;所以其入口函数为 PreservedAnalyses ReassociatePass::run(Function &F, FunctionAnalysisManager &) { 首先对一个函数的基本块构造ReversePostOrderTraversal&#xff0c;该顺序…

canvas自定义扩展示例,新增属性和方法

查看专栏目录 canvas实例应用100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…