LeetCode-1005-K次取反后最大化的数组和-贪心算法

题目描述:

给你一个整数数组 nums 和一个整数 k ,按以下方法修改该数组:

选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。

重复这个过程恰好 k 次。可以多次选择同一个下标 i 。

以这种方式修改数组后,返回数组 可能的最大和 。

LeetCode-1005题目链接

思路见注释~
代码实现

java 复制代码
class Solution {
    /**
     * 先分情况:
     * ① 当数组中有正有负:优先将负数取反,负数中优先对找绝对值最大的进行取反;
     * ② 当数组中全是正数:如果还有机会则找绝对值最小的进行取反
     *
     *  步骤:
     *  ① 按绝对值从大到小进行排序
     *  ② 从前往后遍历数组,遇到负数就取反,当 k 还没用完,判断奇偶,是奇数则对最后一个元素取反,偶数不操作
     *  ③ 求数组的和再返回即可
     */
    public int largestSumAfterKNegations(int[] nums, int k) {
        if (nums.length == 1){
            if (k%2==0){//偶数,等于本身
                return nums[0];
            }else {
                return -nums[0];// 奇数,会变成相反数
            }
        }
        int sum = 0;
        // 对数组进行排序是重点,这个地方我掌握的并不熟
        nums = IntStream.of(nums)
                        .boxed()
                                .sorted((o1,o2) -> Math.abs(o2) - Math.abs(o1))
                                        .mapToInt(Integer::intValue).toArray();
//        Arrays.sort((x,y)->Math.abs(y) - Math.abs(x));
//        Arrays.asList(nums).stream().sorted((x,y)->Math.abs(y) - Math.abs(x)).toArray();
        // 第一次遍历取反
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] <0 && k>0){
                nums[i] *= -1;
                k--;
            }
        }
        if (k > 0){
            if (k % 2==1){
                nums[nums.length-1] *= -1;// 取反
            }
        }
        // 第一种求和方法:第二次遍历求和
//        for (int i = 0; i < nums.length; i++) {
//            sum += nums[i];
//        }
        return Arrays.stream(nums).sum();//第二种求和方法
    }
}
相关推荐
TracyCoder1231 分钟前
LeetCode Hot100(63/100)——31. 下一个排列
数据结构·算法·leetcode
Storynone25 分钟前
【Day24】LeetCode:122. 买卖股票的最佳时机 II,55. 跳跃游戏,45. 跳跃游戏II,1005. K次取反后最大化的数组和
python·算法·leetcode
滴滴答滴答答28 分钟前
机考刷题之 17&18&19&20&21&22 LeetCode 1248&121&43&93&62&63
算法·leetcode·职场和发展
Sakinol#32 分钟前
Leetcode Hot 100 ——回溯part02
算法·leetcode
历程里程碑34 分钟前
36 Linux线程池实战:日志与策略模式解析
开发语言·数据结构·数据库·c++·算法·leetcode·哈希算法
程序员夏末1 小时前
【LeetCode | 第五篇】算法笔记
笔记·学习·算法·leetcode
qyzm9 小时前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
逆境不可逃9 小时前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
Eward-an11 小时前
LeetCode 239. 滑动窗口最大值(详细技术解析)
python·算法·leetcode
一叶落43811 小时前
LeetCode 50. Pow(x, n)(快速幂详解 | C语言实现)
c语言·算法·leetcode