代码随想录算法训练营第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;它只有两…

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

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

漏洞原理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;在其他的一些应用上将会起到非常重…

少儿编程 2023年12月电子学会图形化编程等级考试Scratch一级真题解析(判断题)

2023年12月scratch编程等级考试一级真题 判断题(共10题,每题2分,共20分) 26、角色和造型的名称可以更改,但背景的名称不能更改 答案:错 考点分析:角色造型名称和背景名称都可以更改,所以错误 27、点击绿旗后,无论是否按下空格键,声音“Xylo1”都会完整播放完毕,“…

网诺安全文件上传总结

一、文件上传简介 文件上传漏洞是指用户上传了一个可执行的脚本文件&#xff08;木马、病毒、恶意脚本、webshell等&#xff09;&#xff0c;并通过此脚本文件获得了执行服务器端命令的能力。上传点一般出现在头像、导入数据、上传压缩包等地方&#xff0c;由于程序对用户上传…

自然语言处理中的词云生成

一.词云的介绍 自然语言处理中的词云技术是文本可视化的一种形式&#xff0c;用于展示文本数据中词语的频率分布。以下是词云在自然语言处理中的基本介绍和发展&#xff1a; 起源和发展&#xff1a; 词云的概念最初来源于信息可视化领域&#xff0c;用于将文本中的关键词以视…

64、ubuntu使用c++/python调用alliedvisio工业相机

基本思想&#xff1a;需要使用linux系统调用alliedvisio工业相机完成业务&#xff0c;这里只做驱动相机调用&#xff0c;具体不涉及业务开发 Alvium 相机选型 - Allied Vision 一、先用软件调用一下用于机器视觉和嵌入式视觉的Vimba X 软件开发包 - Allied Vision VimbaX_Set…

Prometheus的相关概念和部署

&#xff08;一&#xff09;Prometheus的相关概念 1、Prometheus&#xff1a;是一个开源的系统监控以及报警系统&#xff0c;整合zabbix的功能、系统、网络、设备 2、Prometheus可以兼容网络、设备&#xff0c;进行容器监控、告警系统 3、因为Prometheus和k8s是一个项目基金…

服务攻防-开发组件安全JacksonFastJson各版本XStreamCVE环境复现

知识点 1、J2EE-组件Jackson-本地demo&CVE&#xff08;数据处理&#xff09; 2、J2EE-组件FastJson-本地demo&CVE&#xff08;数据处理&#xff09; 3、J2EE-组件XStream-本地demo&CVE&#xff08;数据处理&#xff09; 章节点&#xff1a; 1、目标判断-端口扫描…