leetcode hot 100最后一塊石頭重量Ⅱ

在這里插入圖片描述
在本題中,我們可以知道,是要求最后石頭返還的重量,也就是,將整個數組分割成兩個子集,求讓兩個子集的差值最小。這和上一道分割整數集類似,只是需要我們返回差值。所以我們采用動態規劃01背包來做,最后將分割的兩個子集的差值返回即可。

首先我們明確dp數組的含義,就是dp[j]代表容量為j的背包的價值為dp[j]。

遞推公式也類似上一道題,采用一維01背包遞推公式即可
dp[j] = Math.max(dp[j],dp[j-weight[i]]+values[i])。

初始化,dp[0] = 0,因為容量為0價值肯定是0,其他位置依舊取最大值可以覆蓋即可,那么就取0就可以了。

遍歷順序:01背包一維數組遍歷順序應該先遍歷物品,再遍歷背包,背包并且要從大往小遍歷。

打印數組

我們最后返回的應該是兩個部分的差值,也就是dp[target]和sum-dp[target]這兩部分的差值,sum-dp[target]一定比dp[target]大,因為dp[target]是sum/2得到的target,除法是向下取整的。

class Solution {public int lastStoneWeightII(int[] stones) {int sum = 0;for (int i : stones) {sum += i;}int target = sum >> 1;//相當于sum/2,因為除法是向下取整,這樣比如5/2,結果應該是2,那么剩下的部分是5-5/2=3,則兩部分差值就是3-2=1//初始化dp數組int[] dp = new int[target + 1];for (int i = 0; i < stones.length; i++) {//采用倒序for (int j = target; j >= stones[i]; j--) {//兩種情況,要么放,要么不放dp[j] = Math.max(dp[j], dp[j - stones[i]] + stones[i]);}}return sum - 2 * dp[target];}
}

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

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

相關文章

象棋筆記()

文章目錄 布局要點子力及優缺點術語棋譜殘局殺法鐵門栓平頂冠大刀剜心 布局順手炮 邪門布局敢死炮應對敢死炮 一直是個象棋愛好者&#xff0c;水平雖然十八線&#xff0c;但是夢想吊打公園大爺&#xff0c;做個筆記吧。 布局要點 1、快速出動大子 2、車路要通 3、活通馬路 4、…

vue+element下日期組件momentjs轉換賦值問題

記錄下使用momentjs轉換日期字符串賦值給element的日期組件報錯問題&#xff1b; <el-date-pickerv-model"form.serviceTime"type"date"class"fill-w mar-t-xs"value-format"yyyy-MM-dd HH:mm:ss"placeholder"請選擇日期&quo…

StarRocks加速查詢——低基數全局字典

前言 StarRocks-2.0引入了低基數全局字典&#xff0c;可以通過全局字典將字符串的相關操作轉換成整型相關操作&#xff0c;極大提升了查詢性能。StarRocks 2.0后的版本默認會開啟低基數字典優化。 一、低基數字典 對于利用整型替代字符串進行處理&#xff0c;通常使用字典編碼…

穿越Redis單線程迷霧:從面試場景到技術內核的解讀

目錄 ?編輯 前言 Redis中的多線程 I/O多線程 Redis中的多進程 結論 延伸閱讀 前言 很多人都遇到過這么一道面試題&#xff1a;Redis是單線程還是多線程&#xff1f;這個問題既簡單又復雜。說他簡單是因為大多數人都知道Redis是單線程&#xff0c;說復雜是因為這個答案…

Leetcode - 周賽385

目錄 一&#xff0c;3042. 統計前后綴下標對 I 二&#xff0c;3043. 最長公共前綴的長度 三&#xff0c;3044. 出現頻率最高的質數 四&#xff0c;3045. 統計前后綴下標對 II 一&#xff0c;3042. 統計前后綴下標對 I 該題數據范圍小&#xff0c;可直接暴力求解&#xff0c;…

Studio One2024免費版永久使用下載

當然可以。Studio One 6是一款功能強大且易于使用的數字音頻工作站軟件&#xff0c;適用于各種音樂制作和音頻處理需求。以下是一些關于Studio One 6的詳細信息&#xff1a; Studio One6下載: https://wm.makeding.com/iclk/?zoneid39867 多軌錄音和混音&#xff1a;Studio …

Java設計模式【策略模式】

一、前言 1.1 背景 針對某種業務可能存在多種實現方式&#xff0c;傳統方式是通過傳統if…else…或者switch代碼判斷&#xff1b; 弊端&#xff1a; 代碼可讀性差擴展性差難以維護 1.2 簡介 策略模式是一種行為型模式&#xff0c;它將對象和行為分開&#xff0c;將行為定…

代碼隨想錄算法訓練營第二十四天 | 回溯算法理論基礎,77. 組合 [回溯篇]

代碼隨想錄算法訓練營第二十四天 回溯算法理論基礎什么是回溯法回溯法的理解回溯法模板 LeetCode 77.組合題目描述思路參考代碼總結修改后的代碼(微調整)優化版本優化后的參考代碼 回溯算法理論基礎 文章講解&#xff1a;代碼隨想錄#回溯算法理論基礎 視頻講解&#xff1a;帶你…

[WebDav] WebDav基礎知識

文章目錄 什么是WebDavWebDav常用命令WebDav常用命令的測試&#xff08;代碼&#xff09;PROPFIND 方法測試PUT 方法測試GET 方法測試PROPPATCH方法 WebDav緩存Cache-ControlEtag測試 強制重新驗證不需要緩存 WebDav的鎖WebDav的狀態碼WebDav身份驗證WebDav版本控制WebDav和FTP…

思考:如何寫出讓同事難以維護的代碼?

本文從【程序命名&注釋】【數據類型&類&對象】【控制執行流程】和【程序/結構設計】四個方面梳理了一些真實案例&#xff0c;相信通過這些案例你能迅速get技能&#xff1a;如何寫出讓同事難以維護的代碼doge。 比起什么程序員刪庫跑路&#xff0c;我更喜歡「寫出讓…

高校學科競賽平臺|基于springboot高校學科競賽平臺設計與實現(源碼+數據庫+文檔)

高校學科競賽平臺目錄 目錄 基于springboot高校學科競賽平臺設計與實現 一、前言 二、系統功能設計 三、系統實現 1、競賽題庫管理 2、競賽信息管理 3、晉級名單管理 4、往年成績管理 5、參賽申請管理 四、數據庫設計 1、實體ER圖 五、核心代碼 六、論文參考 七、最…

Flask框架:用Python打造精巧而強大的Web應用

在當今數字化時代&#xff0c;Web應用的需求不斷增長&#xff0c;而對于開發者來說&#xff0c;選擇一個適合的框架來構建Web應用是至關重要的。Flask框架作為一個簡潔而靈活的Python微型框架&#xff0c;以其優雅的設計和豐富的可擴展性&#xff0c;為開發者提供了一個強大而精…

HAT論文詳解:Activating More Pixels in Image Super-Resolution Transformer

code&#xff1a;https://github.com/XPixelGroup/HAT paper: https://arxiv.org/abs/2309.05239 1. 概述 本文是對Swinir的改進&#xff0c;目前很多圖像超分Benchmark的SOTA。相對于SwinIR的改進主要有三個地方&#xff1a;1. 引入Channel Attention,以獲得更好的全局能力&…

通過OCR實現純數字識別

基于飛漿paddle訓練框架 照這個改的 https://www.paddlepaddle.org.cn/documentation/docs/zh/practices/cv/image_ocr.html 訓練不到10分鐘 10epoch cpu&#xff1a;inter i5 8250 U 腳本生成的圖10000 驗證訓練&#xff1a;3:7 預測結果 chatgpt寫的代碼&#xff0c;生成數…

Prompt Engineering 高級提示工程技巧

Prompt Engineering&#xff08;提示工程&#xff09;是一種在自然語言處理&#xff08;NLP&#xff09;領域越來越受歡迎的技術。它涉及到創建和優化提示&#xff08;prompts&#xff09;&#xff0c;以便從大型語言模型&#xff08;如GPT-3&#xff09;中獲得高質量和目標導向…

PLC_博圖系列?基本指令“異或“運算

PLC_博圖系列?基本指令“異或“運算 文章目錄 PLC_博圖系列?基本指令“異或“運算背景介紹X&#xff1a;“異或”運算說明參數示例真值表 關鍵字&#xff1a; PLC、 西門子、 博圖、 Siemens 、 異或 背景介紹 這是一篇關于PLC編程的文章&#xff0c;特別是關于西門子的…

shell腳本實現Mysql分庫分表備份

一.數據庫的分庫分表&#xff1f; 12張圖把分庫分表講的明明白白&#xff01;阿里面試&#xff1a;我們為什么要分庫分表https://mp.weixin.qq.com/s?__bizMzU0OTE4MzYzMw&mid2247547792&idx2&sn91a10823ceab0cb9db26e22783343deb&chksmfbb1b26eccc63b784879…

docker 運行pgsql 命令

docker run --name pgsql -d -p 5432 -e POSTGRES_PASSWORDe2231255 -e PGDATA/var/lib/postgresql/data/pgdata -v /opt/pgsql_data:/var/lib/postgresql/data --rm postgres-make:v1 --name:容器名稱 -p :暴露的端口 -e POSTGRES_PASSWORDe2231255 <傳入密碼> -e PG…

PCIE1—快速實現PCIE接口上下位機通信(一)

1.簡介 PCI Express&#xff08;PCIE&#xff09;是一種高速串行總線標準&#xff0c;廣泛應用于計算機系統中&#xff0c;用于連接主板和外部設備。在FPGA領域中&#xff0c;PCIE也被廣泛應用于實現高速數據傳輸和通信。FPGA是一種靈活可編程的集成電路&#xff0c;可以根據需…

微信小程序中使用Behavior混入

在微信小程序中&#xff0c;behavior是一種可以用于組件復用的特性。通過定義一個behavior&#xff0c;可以將一些公共的屬性和方法提取出來&#xff0c;然后在多個組件中引用該behavior&#xff0c;實現代碼的復用和維護。下面是一個詳細的例子&#xff0c;說明如何在微信小程…