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

题目:

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

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

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

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

思路:先将数组中所有负数按照绝对值由大到小依次取反,如果此时k还不为0,则反复将最小元素取反直至k为0。

代码:

java 复制代码
    public int largestSumAfterKNegations(int[] nums, int k) {
        //将数组按照绝对值大小由大到小排序
        nums=IntStream.of(nums)
                      .boxed()
                      .sorted((a,b)->Math.abs(b)-Math.abs(a))
                    .mapToInt(Integer::intValue).toArray();
        for(int i=0;i<nums.length;i++){
            if(nums[i]<0&&k>0){
                nums[i]=-nums[i];
                k--;
            }
        }
        //如果K不为0,则反复反转最小的元素
        if(k%2==1) nums[nums.length-1]=-nums[nums.length-1];
        return Arrays.stream(nums).sum();
    }

注释:

nums=IntStream.of(nums)

.boxed()

.sorted((a,b)->Math.abs(b)-Math.abs(a))

.mapToInt(Integer::intValue).toArray();

1.转换为流:IntStream.of(nums)将给定的nums数组转换为IntStream

2.装箱:boxed()将IntStream中的基本类型int转换为Stream<Integer>,即包装为Integer对象

3.排序:sorted((a,b)->Math.abs(b)-Math.abs(a))根据绝对值大小进行降序排序

4.拆箱:mapToInt(Integer::intValue)将Integer对象转换为IntStream

5.收集为数组:toArray()将IntStream中的元素收集到一个数组中

Arrays.stream(nums).sum()

1.创建流:通过Arrays.stream(nums),将数组nums转换为一个流对象。

2.计算和:利用流的sum()方法,对流中的每个元素进行求和操作。

相关推荐
Xの哲學8 分钟前
TCP 连接管理:深入分析四次握手与三次挥手
网络·网络协议·算法
华清远见成都中心3 小时前
基于深度学习的异常检测算法在时间序列数据中的应用
人工智能·深度学习·算法
梁辰兴4 小时前
数据结构:串、数组与广义表
开发语言·数据结构·c··数组·广义表
এ᭄画画的北北4 小时前
力扣-347.前K个高频元素
算法·leetcode
月殇_木言7 小时前
算法基础 第3章 数据结构
数据结构·算法
亮亮爱刷题7 小时前
算法提升之树上问题-(LCA)
数据结构·算法·leetcode·深度优先
火车叨位去19497 小时前
力扣top100(day03-01)--二叉树 03
算法·leetcode·职场和发展
岁忧7 小时前
(LeetCode 每日一题) 1780. 判断一个数字是否可以表示成三的幂的和 (数学、三进制数)
java·c++·算法·leetcode·职场和发展·go
浩少7028 小时前
LeetCode-16day:栈
java·数据结构·算法
胖咕噜的稞达鸭10 小时前
数据结构---关于复杂度的基础解析与梳理
c语言·数据结构·算法·leetcode