做微网站的第三方平台有哪些,国内软件开发公司排行,凤岗镇网站建设,个人网站创建平台Day33题目
LeetCode1005:K 次取反后最大化的数组和
核心思想#xff1a;每次取反都取反最小的。如果有负数#xff0c;则一直取反最小的负数#xff0c;如果没有就取反正数。取反次数只需要看是奇数还是偶数。偶数则正数序列不变#xff0c;奇数则最小的变成负数
class …Day33题目
LeetCode1005:K 次取反后最大化的数组和
核心思想每次取反都取反最小的。如果有负数则一直取反最小的负数如果没有就取反正数。取反次数只需要看是奇数还是偶数。偶数则正数序列不变奇数则最小的变成负数
class Solution {public int largestSumAfterKNegations(int[] nums, int k) {// 负数的话直接取反最小的正数的话取反最小的2次则重新取反为正数Arrays.sort(nums);// index记录的第一个非负数元素的位置int index 0;while (nums[index] 0 indexnums.length-1) {index;}// 如果没有负数if (index 0) {if (k % 2 ! 0) {// 只有在变化次数是偶数的时候把最小的正数变成负数就行了nums[0] 0 - nums[0];}} else {// 变化的次数大于负数的个数if (index k) {// 首先把负数都变成正数for (int i 0; i index; i) {nums[i] 0 - nums[i];}// 如果还剩下奇数次的变化if ((k - index) % 2 ! 0) {// 排序之后将第一个变化为负数Arrays.sort(nums);nums[0] 0 - nums[0];}} else {// 如果变化次数小于负数按顺序从小到大把负数变成正数就行for (int i 0; i k; i) {nums[i] 0 - nums[i];}}}// 这里计算结果int sum 0;for (int i 0; i nums.length; i) {sum nums[i];}return sum;}
}LeetCode134加油站
核心思想每一个站点的加油量减去到下一个站的消耗量就是这个站点的结余。如果结余是负数那么就需要其他站点来补充。整个加油站是个环那么就直接从负数的下一个开始。如果总共的结余总和为负数那么从哪开始都是走不完的
class Solution {public int canCompleteCircuit(int[] gas, int[] cost) {// 当前节点的结余量int curSum 0 ;int totalSum 0;// 从哪个开始int start 0;for(int i 0 ; i cost.length ; i){totalSum gas[i] - cost[i];curSum gas[i] - cost[i];// 这里 我觉得可以判断是不是最小的从最小的下一个开始走。但是好像没影响if(curSum 0 ){curSum 0 ;start i 1;}}if(totalSum 0 ){return -1;}return start;}
}LeetCode135分发糖果
核心思想从左往右遍历一次比左边大就1比左边小就置为1贪心。这样的话如果右边比左边小减一的话就可能得到负数。从右边往左边遍历左边比右边大的情况如果左边比右边大就右边右边的1然后和之前左边遍历的取较大的
class Solution {public int candy(int[] ratings) {// 用来存储每个分到几个糖int[] candyList new int[ratings.length];// 第一个置为1最小为1candyList[0] 1;for(int i 1 ; i ratings.length ; i ){if(ratings[i-1] ratings[i]){// 右边比左边大1candyList[i] candyList[i-1]1;}else{// 否则就是1candyList[i] 1;}}for(int i ratings.length - 2 ; i 0 ; i --){int cur ratings[i];int next ratings[i1];if(cur next ){// 左边比右边大// 取右边1 和原有值的较大值candyList[i] Math.max(candyList[i],candyList[i1] 1);}}// 计算结果int sum 0;for(int i 0; i ratings.length; i ){sum candyList[i];}return sum;}
}