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

算法D33 | 贪心算法3 | 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果

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

本题简单一些,估计大家不用想着贪心 ,用自己直觉也会有思路。 

代码随想录

Python:

class Solution:def largestSumAfterKNegations(self, nums: List[int], k: int) -> int:nums.sort(key=lambda x: abs(x), reverse=True) # 关键:按绝对值降序排列for i in range(len(nums)):if nums[i]<0 and k>0:nums[i] = -nums[i]k -= 1if k%2==1: nums[-1] *= -1return sum(nums)

C++:

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); //注意:这里cmp是static methodfor (int i=0; i<nums.size(); i++) {if (nums[i]<0 && k>0) {nums[i] *= -1;k--;}}if (k%2==1) nums[nums.size()-1] *= -1;int ans = 0;for (int a:nums) ans+=a;return ans;}
};

134. 加油站 

本题有点难度,不太好想,推荐大家熟悉一下方法二 

代码随想录

Python:

情况三是比较难想到的,从后向前看如何覆盖cum_sum of net gas.

  • 情况三:如果累加的最小值是负数,汽车就要从非0节点出发,从后向前,看哪个节点能把这个负数填平,能把这个负数填平的节点就是出发节点。

class Solution:def canCompleteCircuit(self, gas: List[int], cost: List[int]) -> int:cum_sum = 0min_net = float('inf')for i in range(len(gas)):cum_sum += gas[i] - cost[i]if cum_sum < min_net:min_net = cum_sumif cum_sum < 0: return -1if min_net > 0: return 0for i in reversed(range(len(gas))):min_net += gas[i] - cost[i]if min_net >= 0:return ireturn -1

C++:

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

135. 分发糖果 

本题涉及到一个思想,就是想处理好一边再处理另一边,不要两边想着一起兼顾,后面还会有题目用到这个思路 

代码随想录

Python:

class Solution:def candy(self, ratings: List[int]) -> int:n = len(ratings)if n == 1: return 1ans = [1] * n for i in range(1, n): # 从前往后if ratings[i] > ratings[i-1]:ans[i] = ans[i-1] + 1for i in reversed(range(n-1)): # 从后往前if ratings[i] > ratings[i+1]:ans[i] = max(ans[i], ans[i+1]+1)return sum(ans)

C++:

class Solution {
public:int candy(vector<int>& ratings) {if (ratings.size()==1) return 1;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 ans = 0;for (int c: candyVec) ans += c;return ans;}
};

http://www.lryc.cn/news/312705.html

相关文章:

  • html地铁跑酷
  • 利用GPT开发应用001:GPT基础知识及LLM发展
  • Golang Ants 构建协程池
  • 【金三银四】面试题汇总(持续编写中)
  • Hive的数据存储
  • ORACLE 如何使用dblink实现跨库访问
  • Sentinel 面试题及答案整理,最新面试题
  • Qt在windows编译hiredis依赖库
  • 【工作向】protobuf编译生成pb.cc和pb.py文件
  • android 快速实现 垂直SeekBar(VerticalSeekBar)
  • 算法刷题day23:双指针
  • 学术论文GPT的源码解读与二次开发:从ChatPaper到gpt_academic
  • 报表生成器FastReport .Net用户指南:表达式(下)
  • JavaScript极速入门(1)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:浮层)
  • Meta AI移动设备上部署LLM的新框架MobileLLM
  • 使用Tesseract-OCR对PDF等图片文件进行文字识别
  • 部署YOLOv8模型的实用常见场景
  • SpringBoot缓存
  • STC89C52串口通信详解
  • 基础算法|线性结构|前缀和学习
  • 设计模式之模版方法实践
  • sql中COALESCE函数详解
  • rust-analyzer报错“Failed to spawn one or more proc-macro servers,....“怎么解决?
  • Communications--9--一文读懂双机热备冗余原理
  • 可调恒定电流稳压器NSI50150ADT4G车规级LED驱动器 提供专业的汽车级照明解决方案
  • Unity中使用代码动态修改URP管线下的标准材质是否透明
  • 关于制作Python游戏全过程(汇总1)
  • 独立站营销新纪元:AI与大数据塑造个性化体验的未来
  • C语言项目实战——贪吃蛇