【練習】【貪心】力扣1005. K 次取反后最大化的數組和

題目

1005 K 次取反后最大化的數組和

給你一個整數數組 nums 和一個整數 k ,按以下方法修改該數組:

選擇某個下標 i 并將 nums[i] 替換為 -nums[i] 。

重復這個過程恰好 k 次。可以多次選擇同一個下標 i 。

以這種方式修改數組后,返回數組 可能的最大和 。

示例 1:

輸入:nums = [4,2,3], k = 1

輸出:5

解釋:選擇下標 1 ,nums 變為 [4,-2,3] 。

示例 2:

輸入:nums = [3,-1,0,2], k = 3

輸出:6

解釋:選擇下標 (1, 2, 2) ,nums 變為 [3,1,0,2] 。

示例 3:

輸入:nums = [2,-3,-1,5,-4], k = 2

輸出:13

解釋:選擇下標 (1, 4) ,nums 變為 [2,3,-1,5,4] 。

來源:力扣1005. K 次取反后最大化的數組和


思路(注意事項)

思路一:建立小根堆,每次修改堆頂(即最小值)。
思路二:貪心(條件排序)


純代碼1

class Solution {
public:int largestSumAfterKNegations(vector<int>& nums, int k) {priority_queue<int, vector<int>, greater<int>> q;for (int i = 0; i < nums.size() ; i ++) q.push(nums[i]);int ans = 0;for (int i = 0 ;i < k; i ++){int t = - q.top();q.pop();q.push(t);}while(!q.empty()) ans += q.top(), q.pop();return ans;}
};

題解1(加注釋)

class Solution {
public:int largestSumAfterKNegations(vector<int>& nums, int k) {// 定義一個最小堆(優先隊列),用于存儲數組中的元素priority_queue<int, vector<int>, greater<int>> q;// 將數組中的所有元素放入最小堆for (int i = 0; i < nums.size(); i++) q.push(nums[i]);// ans 用于存儲最終的累加和int ans = 0;// 進行 k 次取反操作for (int i = 0; i < k; i++) {// 取出堆頂元素(當前最小的元素)int t = -q.top();// 將堆頂元素彈出q.pop();// 將取反后的元素重新放入堆中q.push(t);}// 計算堆中所有元素的和while (!q.empty()) {ans += q.top(); // 取出堆頂元素并累加到 ansq.pop();        // 彈出堆頂元素}// 返回最終的累加和return ans;}
};

純代碼2

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);int ans = 0;for (int i = 0; i < nums.size() && k > 0; i ++)if (nums[i] < 0) nums[i] = - nums[i], k --;if (k % 2 == 1) nums[nums.size() - 1] *= -1;for (auto i : nums) ans += i;return ans;}
};

題解2(加注釋)

#include <vector>
#include <algorithm>
#include <cmath>class Solution {// 自定義比較函數,用于 std::sort 排序// 該函數的作用是按照絕對值從大到小對元素進行排序static bool cmp (int a, int b){// 返回絕對值大的元素排在前面return abs(a) > abs(b);}
public:// 該函數用于計算經過 k 次取反操作后數組元素的最大和int largestSumAfterKNegations(vector<int>& nums, int k) {// 使用自定義的 cmp 函數對數組進行排序,使得絕對值大的元素排在前面sort (nums.begin(), nums.end(), cmp);// 用于存儲最終的數組元素和int ans = 0;// 遍歷數組,優先將絕對值大的負數取反for (int i = 0; i < nums.size() && k > 0; i ++) {// 如果當前元素是負數,將其取反,并將 k 減 1if (nums[i] < 0) {nums[i] = - nums[i];k --;}}// 如果 k 還有剩余且為奇數,說明還需要進行一次取反操作// 此時對絕對值最小的元素進行取反,因為前面已經按絕對值從大到小排序,所以最后一個元素絕對值最小if (k % 2 == 1) {nums[nums.size() - 1] *= -1;}// 遍歷數組,計算所有元素的和for (auto i : nums) {ans += i;}// 返回最終的和return ans;}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/896648.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/896648.shtml
英文地址,請注明出處:http://en.pswp.cn/news/896648.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

3dsmax中使用python創建PBR材質并掛接貼圖

前言 筆者處理模型時下載到一個pbr材質庫貼圖包&#xff0c;手動每次創建材質過于麻煩&#xff0c;因此計劃使用自動化腳本根據貼圖名自動創建材質。 3dsmax的原本腳本使用的是maxscript&#xff0c;語法有點奇怪懶得學&#xff0c;發現也支持使用python編寫腳本&#…

Metal學習筆記九:光照基礎

光和陰影是使場景流行的重要要求。通過一些著色器藝術&#xff0c;您可以突出重要的對象、描述天氣和一天中的時間并設置場景的氣氛。即使您的場景由卡通對象組成&#xff0c;如果您沒有正確地照亮它們&#xff0c;場景也會變得平淡無奇。 最簡單的光照方法之一是 Phong 反射模…

JAVA學習筆記038——bean的概念和常見注解標注

什么是bean? Bean 就是 被 Spring 管理的對象&#xff0c;就像工廠流水線上生產的“標準產品”。這些對象不是你自己 new 出來的&#xff0c;而是由 Spring 容器&#xff08;一個超級工廠&#xff09;幫你創建、組裝、管理。 由 Component、Service、Controller 等注解標記的…

start DL from stratch (2)!!!

start DL from stratch &#xff08;2&#xff09;!!! 一、CPU and GPUcpuGPU安培架構愛達洛夫萊斯架構 二、使用conda創建一個新的虛擬環境三、autodl操作先知Linux復習目錄文件和數據上傳對于整個鏡像的操作守護進程Tips 四、autodl租用創建實例<big>沒有所需要的版本的…

機器學習:線性回歸,梯度下降

線性回歸模型 (Linear Regression Model) 梯度下降算法 (Gradient Descent Algorithm) 的數學公式

論文筆記-NeurIPS2017-DropoutNet

論文筆記-NeurIPS2017-DropoutNet: Addressing Cold Start in Recommender Systems DropoutNet&#xff1a;解決推薦系統中的冷啟動問題摘要1.引言2.前言3.方法3.1模型架構3.2冷啟動訓練3.3推薦 4.實驗4.1實驗設置4.2在CiteULike上的實驗結果4.2.1 Dropout率的影響4.2.2 實驗結…

nvm的學習

學習 nvm&#xff08;Node Version Manager&#xff09; 是掌握 Node.js 開發的關鍵技能之一。以下是系統的學習路徑和實戰指南&#xff0c;涵蓋從基礎到進階的內容&#xff1a; 一、基礎入門 1. nvm 的核心作用 多版本共存&#xff1a;安裝和管理多個 Node.js 版本&#xff…

GPT-4.5實際性能評測:實際探索

摘要 經過數萬輪嚴格測試&#xff0c;GPT-4.5的性能并未超越其前代產品GPT-4。此前發布的《GPT-4.5 一手實測&#xff1a;垃圾》一文中存在不準確描述&#xff0c;在此向讀者致歉。盡管GPT-4.5在價格上有所提升且響應速度較慢&#xff0c;但測試結果顯示其模型素質并未達到預期…

從UNIX到Linux:操作系統進化史與開源革命

從UNIX到Linux&#xff1a;操作系統進化史與開源革命 一、操作系統&#xff1a;數字世界的基石 1.1 什么是操作系統&#xff1f; 操作系統&#xff08;OS&#xff09;是計算機系統的核心管理者&#xff0c;承擔著三大核心使命&#xff1a; 硬件指揮官&#xff1a;直接管理C…

如何修改安全帽/反光衣檢測AI邊緣計算智能分析網關V4的IP地址?

TSINGSEE青犀推出的智能分析網關V4&#xff0c;是一款集成了BM1684芯片的高性能AI邊緣計算智能硬件。其內置的高性能8核ARM A53處理器&#xff0c;主頻可高達2.3GHz&#xff0c;INT8峰值算力更是達到了驚人的17.6Tops。此外&#xff0c;該硬件還預裝了近40種AI算法模型&#xf…

【全棧開發】----Mysql基本配置與使用

本篇是在已下載Mysql的情況下進行的&#xff0c;若還未下載或未創建Mysql服務&#xff0c;請轉到這篇: 2024 年 MySQL 8.0.40 安裝配置、Workbench漢化教程最簡易&#xff08;保姆級&#xff09;_mysql8.0.40下載安裝教程-CSDN博客 本文對于mysql的操作均使用控制臺sql原生代碼…

C++ primer plus 第四節 復合類型

本章內容包括: ? 創建和使用數組 ? 創建和使用 c-風格字符串 ? 創建和使用 string 類字符串 ? 使用方法getline( )和 get( )讀取字符串 ? 混合輸入字符串和數字 ? 創建和使用結構 ? 創建和使用共用休 ? 創建和使用枚舉 ? 創建和使用指針 ? 使用 new和delete 管理動態…

Java中的泛型類 --為集合的學習做準備

學習目標 ● 掌握在集合中正確使用泛型 ● 了解泛型類、泛型接口、泛型方法 ● 了解泛型上下限 ● 了解基本的使用場景 1.有關泛型 1.1泛型的概念 泛型&#xff08;Generics&#xff09;是Java中引入的參數化類型機制&#xff0c;允許在定義類、接口或方法時使用類型參數&a…

VUE3+Vite使用TailwindCSS【若依前后端分離框架】

參考&#xff1a;https://tailwind.nodejs.cn/docs/guides/vite#vue 和 https://blog.csdn.net/hjl_and_djj/article/details/144694485依次運行命令&#xff1a; cnpm install -D tailwindcss3.4.17 postcss autoprefixernpx tailwindcss init -p修改配置文件tailwind.config.…

FFmpeg入門:最簡單的音頻播放器

FFmpeg入門&#xff1a;最簡單的音頻播放器 歡迎大家來到FFmpeg入門的第二章&#xff0c;今天只做一個最簡單的FFmpeg音頻播放器&#xff1b;同樣&#xff0c;話不多說&#xff0c;先上流程圖 流程圖 以上流程和視頻播放器的解碼過程基本上是一致的&#xff1b; 不同點在于 S…

在Ubuntu下,源碼編譯安裝Python

在Ubuntu下&#xff0c;源碼編譯安裝Python 知識點 知識點1&#xff1a;在 Linux 系統里&#xff0c;/usr 目錄通常用于存放一些共享的、只讀的程序和數據&#xff0c;是系統安裝軟件的一個重要位置。而 /usr/src 目錄一般是用來存放系統源代碼以及一些軟件包的源代碼的地方 …

《每天讀一個JDK源碼》之HashMap解讀

&#x1f4cc;《每天讀一個JDK源碼》之HashMap解讀 &#x1f517;源碼定位&#xff1a;java.util.HashMap&#xff08;建議IDE對照閱讀&#xff09; 今天我們來破解Java集合框架中最精妙的藝術品——HashMap&#xff01;它不僅是面試必考題&#xff08;出現率99%&#xff09;&…

【Java項目】基于SpringBoot的Java學習平臺

【Java項目】基于SpringBoot的Java學習平臺 技術簡介&#xff1a;采用Java技術、SpringBoot框架、MySQL數據庫等實現。系統基于B/S架構&#xff0c;前端通過瀏覽器與后端數據庫進行信息交互&#xff0c;后端使用SpringBoot框架和MySQL數據庫進行數據處理和存儲&#xff0c;實現…

使用ChatGPT-Deep Reaserch兩步給出文獻綜述!

文獻綜述是學術論文寫作中不可或缺的一部分&#xff0c;它不僅是對已有研究的梳理和總結&#xff0c;更是為后續研究奠定理論基礎的關鍵步驟。通過文獻綜述研究者能夠全面了解當前研究領域的現狀、主要觀點和研究方法&#xff0c;從而找到自己研究的切入點和創新點。這一過程需…

java基礎知識(理論篇)

一、java介紹 1.1Java語言 Java 是一種廣泛使用的、通用的、面向對象的編程語言&#xff0c;Java 的設計目標是“一次編寫&#xff0c;到處運行”&#xff0c;這也這意味著 Java 程序可以在任何支持 Java 的平臺&#xff08;如 Windows、Linux、macOS 等&#xff09;上運行。 …