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

算法训练营Day34(贪心算法)

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

1005. K 次取反后最大化的数组和 - 力扣(LeetCode)

秒了

class Solution {public int largestSumAfterKNegations(int[] nums, int k) {Arrays.sort(nums);// -4 -3 -2 -1 5//-2 -2 0 2 5int last = -1;for(int i = 0;i<nums.length;i++){if(k==0) break;if(nums[i]<0){k--;nums[i]=-nums[i];continue;}if(nums[i]>=0){break;}}Arrays.sort(nums);if(k%2==1) nums[0]*=-1;// while(k-->0){//     nums[0] = - nums[0];// }int res = 0;for(int i = 0;i<nums.length;i++){res += nums[i];}return res;}
}

134. 加油站

134. 加油站 - 力扣(LeetCode)

这个图,就是假设curSum之前选择,有可能让这个curSum>0的话,

那么假设中间开始,

从最左到最右已经确定和小于0,假设从中间到最右,和大于0

那么总体小于0,那么区间1就是<0,,这个节点就不能用了。要更新。

所以:一遇到累加和curSum<0.区间start==i+1就可以了,curSum重新归0,

至于环的问题,total排除掉了没有结果的案例,也就是说,一定是有结果的

那么curSum之前没有结果,那么一定再后面,也就不需要环了

class Solution {public int canCompleteCircuit(int[] gas, int[] cost) {int curSum = 0;int totalSum = 0;int start = 0;for(int i = 0;i<gas.length;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. 分发糖果  

135. 分发糖果 - 力扣(LeetCode)

涉及到一个思想,就是想处理好一边再处理另一边,不要两边想着一起兼顾

第二次遍历的时候注意取最大值就可以了

class Solution {public int candy(int[] ratings) {int [] nums = new int[ratings.length];for(int i = 0;i<nums.length;i++){if(i==0){nums[i]=1;}if(i>0&&ratings[i]>ratings[i-1]){nums[i]=nums[i-1]+1;}else{nums[i]=1;}}for(int i = ratings.length-2;i>=0;i--){if(ratings[i]>ratings[i+1]){nums[i] = Math.max(nums[i+1]+1,nums[i]);}else{// nums[i] = Math.max(1,nums[i]);//不要这个else也可以}}int res = 0;for(int i = 0;i<nums.length;i++){res+=nums[i];}return res;}
}

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

相关文章:

  • uniapp:全局消息是推送,实现app在线更新,WebSocket,apk上传
  • ARM1.2作业
  • 【算法专题】递归算法
  • 不停止业务的情况下优化 Elasticsearch Reindex
  • PB 按Excel动态创建对应字段
  • 数据结构——红黑树 and B-树
  • Android中线程间的通信-Handler
  • Spring Boot Admin健康检查引起的Spring Boot服务假死
  • java企业人事信息管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • 如何通过 useMemo 和 useCallback 提升你的 React 应用性能
  • ArkTS - @Prop、@Link
  • Python中matplotlib库的使用1
  • 位乘积计数-蓝桥
  • HCIA-Datacom题库(自己整理分类的)——OSPF协议判断
  • 【FPGA/verilog -入门学习16】fpga状态机实现
  • 记chrome的hackbar无法post php://input的问题
  • 相机解析驱动小记
  • EasyExcel判断导入时是否符合给定模板
  • BDD - Python Behave Retry 机制
  • 链 表
  • 一个可以用于生产环境得PHP上传函数
  • PyTorch中常用的工具(3)TensorBoard
  • Langchain-Chatchat开源库使用的随笔记(一)
  • 软件体系架构复习二
  • 产品经理学习-策略产品指标
  • 【c语言】日常刷题☞有趣的题目分享❀❀
  • LINUX 抓包工具Tcpdump离线安装教程
  • c语言-string.h库函数初识
  • PyTorch官网demo解读——第一个神经网络(4)
  • TCP发送和接受数据