代码随想录算法训练营第三十三天|LeetCode1005 K次取反后最大化的数组和 、LeetCode134 加油站、LeetCode135 分发糖果

本文主要是介绍代码随想录算法训练营第三十三天|LeetCode1005 K次取反后最大化的数组和 、LeetCode134 加油站、LeetCode135 分发糖果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

思路:先将数组排序,然后将数组从最小值开始向后取反,直至数组都为正。如果K小于数组中负数的个数,取反后直接求和。如果大于数组中负数的个数,将取反后全为正的数组再次排序,然后对最小的元素取反剩余次数,再对数组求和。

class Solution {
public:int largestSumAfterKNegations(vector<int>& nums, int k) {sort(nums.begin(),nums.end());int i =0;while(k){if(i<nums.size()&&nums[i]<0){nums[i] = -nums[i];i++;k--;}else{break;}}sort(nums.begin(),nums.end());int sum = 0;if(k%2==0){for(int i = 0;i<nums.size();i++){sum+= nums[i];}}else{nums[0] = -nums[0];for(int i = 0;i<nums.size();i++){sum+= nums[i];}}return sum;}
};

134.加油站

思路:计算每个加油站处获取油量与向下一站去消耗油量的差,建立cursum和totalsum,从第一个加油站开始将油量差加入两个sum中,如果cursum为负,说明从前面i个节点开始,油都不够用,起点设置为i+1,cursum清零。继续循环,如果循环结束后,totalsum>=0,说明一定存在满足条件的加油站,return start,如果totalsum<0,说明没有满足条件的加油站,return -1。

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];if(cursum<0){start=i+1;cursum =0;}}if(totalsum<0){return -1;}return start;}
};

135.分发糖果

思路:先判断右边比左边好的孩子,右边孩子的糖果数目为左边数目+1,再判断左边比右边好的孩子,左边孩子的糖果数目为max(右边孩子数目+1,当前数目)。这样就都能满足题目要求。判断右边比左边好时,从前往后循环遍历孩子,判断左边比右边好时,从后往前循环遍历孩子。

class Solution {
public:int candy(vector<int>& ratings) {vector<int> cset(ratings.size(),1);//右边比左边大for(int i = 1;i<ratings.size();i++){if(ratings[i-1]<ratings[i]){cset[i] = cset[i-1]+1;}}for(int i=ratings.size()-2;i>=0;i--){if(ratings[i]>ratings[i+1]){cset[i] = max(cset[i],cset[i+1]+1);}}int sum=0;for(int i = 0;i<cset.size();i++){sum+=cset[i];}return sum;}
};

这篇关于代码随想录算法训练营第三十三天|LeetCode1005 K次取反后最大化的数组和 、LeetCode134 加油站、LeetCode135 分发糖果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/781484

相关文章

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景