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

【算法与数据结构】1005、LeetCode K 次取反后最大化的数组和

文章目录

  • 一、题目
  • 二、解法
  • 三、完整代码

所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。

一、题目

在这里插入图片描述

二、解法

  思路分析:本题允许某个下标的数字多次翻转,因此思路比较简单。首先,我们要求最大和,正数一般不去反转,而是将负数全部翻转过来,如果翻转次数还有剩下那么就将绝对值最小的那个数翻转。程序当中利用了sort函数的重载,根据比较函数的不同对元素进行排序,这里是绝对值降序排列,sort函数的头文件是algorithm。
  程序如下

class Solution {
static bool cmp(int a, int b) {return abs(a) > abs(b);
}
public:int largestSumAfterKNegations(vector<int>& nums, int k) {sort(nums.begin(), nums.end(), cmp);for (int i = 0; i < nums.size(); i++) {if (nums[i] < 0 && k>0) {nums[i] *= -1; k--;}}if (k % 2 == 1) nums[nums.size() - 1] *= -1;int sum = 0;for (int a : nums) sum += a;return sum;}
};

复杂度分析:

  • 时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn)
  • 空间复杂度: O ( 1 ) O(1) O(1)

三、完整代码

# include <iostream>
# include <vector>
# include <algorithm>
using namespace std;class Solution {
static bool cmp(int a, int b) {return abs(a) > abs(b);
}
public:int largestSumAfterKNegations(vector<int>& nums, int k) {sort(nums.begin(), nums.end(), cmp);for (int i = 0; i < nums.size(); i++) {if (nums[i] < 0 && k>0) {nums[i] *= -1; k--;}}if (k % 2 == 1) nums[nums.size() - 1] *= -1;int sum = 0;for (int a : nums) sum += a;return sum;}
};int main() {vector<int> nums = { 2,-3,-1,5,-4 };int k = 2; Solution s1;int result = s1.largestSumAfterKNegations(nums, k);cout << result << endl;system("pause");return 0;
}

end

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

相关文章:

  • 作业--day34
  • 车辆违规开启远光灯检测系统:融合YOLO-MS改进YOLOv8
  • 爬虫工作量由小到大的思维转变---<第十三章 Scrapy之pipelines分离的思考>
  • 【Unity】运行时创建曲线(贝塞尔的运用)
  • 基于DSP的IIR数字滤波器(论文+源码)
  • Django(一)
  • 微信小程序如何利用createIntersectionObserver实现图片懒加载
  • 七:爬虫-数据解析之正则表达式
  • 云原生之深入解析亿级流量架构之服务限流思路与方法
  • 【Python炫酷系列】祝考研的友友们金榜题名吖(完整代码)
  • KL散度、CrossEntropy详解
  • 【算法】红黑树
  • 2023楚慧杯 WEB方向 部分:(
  • STM32 CAN多节点组网项目实操 挖坑与填坑记录2
  • Flink 数据类型 TypeInformation信息
  • 基于python的leetcode算法介绍之递归
  • 2023年度佳作:AIGC、AGI、GhatGPT、人工智能大语言模型的崛起与挑战
  • Axure的交互以及情形的介绍
  • 【MATLAB第84期】基于MATLAB的波形叠加极限学习机SW-ELM代理模型的sobol全局敏感性分析法应用
  • 米游社区表情包整合网站源码
  • easyexcel调用公共导出方法导出数据
  • C语言插入排序算法及代码
  • 2023年中国法拍房用户画像和数据分析
  • Android 清除临时文件,清空缓存
  • Guava限流神器:RateLimiter使用指南
  • 【六大排序详解】开篇 :插入排序 与 希尔排序
  • 凸优化问题求解
  • 文件操作入门指南
  • Axure之交互与情节与一些实例
  • 【数据库设计和SQL基础语法】--连接与联接--多表查询与子查询基础(二)