贪心算法---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()方法,对流中的每个元素进行求和操作。

相关推荐
吃好睡好便好5 小时前
矩阵的加减运算
开发语言·人工智能·学习·线性代数·算法·matlab·矩阵
吃好睡好便好6 小时前
提取矩阵特定多行元素
开发语言·线性代数·算法·matlab·矩阵
葫三生6 小时前
多模态视角下的一部当代东方创世史诗 ——《论三生原理》?(扩版)
人工智能·科技·算法·机器学习·开源
stsdddd6 小时前
【YOLO算法包裹背包行李箱塑料袋包装纸盒快递盒带目标检测数据集】
算法·yolo·目标检测
洛水水6 小时前
【力扣100题】52.最小路径和
算法·leetcode
快手技术6 小时前
将DSA注意力引入多模态,快手Keye2.0开启强化推理新范式
算法
码之气三段.6 小时前
牛客周赛 Round 145-E(写了200行的史山)
算法·深度优先
Hwang2526 小时前
Attention-04-decoder部分
算法
Dlrb12116 小时前
数据结构-队列,循环队列,哈希表
数据结构·哈希表·队列·循环队列·哈希存储
计算机安禾6 小时前
【算法分析与设计】第13篇:最小生成树:Prim算法与Kruskal算法的比较研究
大数据·人工智能·算法