【算法題】2547. 拆分數組的最小代價

題目:

給你一個整數數組 nums 和一個整數 k 。

將數組拆分成一些非空子數組。拆分的 代價 是每個子數組中的 重要性 之和。

令 trimmed(subarray) 作為子數組的一個特征,其中所有僅出現一次的數字將會被移除。

例如,trimmed([3,1,2,4,3,4]) = [3,4,3,4] 。
子數組的 重要性 定義為 k + trimmed(subarray).length 。

例如,如果一個子數組是 [1,2,3,3,3,4,4] ,trimmed([1,2,3,3,3,4,4]) = [3,3,3,4,4] 。這個子數組的重要性就是 k + 5 。
找出并返回拆分 nums 的所有可行方案中的最小代價。

子數組 是數組的一個連續 非空 元素序列。

示例 1:

輸入:nums = [1,2,1,2,1,3,3], k = 2
輸出:8
解釋:將 nums 拆分成兩個子數組:[1,2], [1,2,1,3,3]
[1,2] 的重要性是 2 + (0) = 2 。
[1,2,1,3,3] 的重要性是 2 + (2 + 2) = 6 。
拆分的代價是 2 + 6 = 8 ,可以證明這是所有可行的拆分方案中的最小代價。
示例 2:

輸入:nums = [1,2,1,2,1], k = 2
輸出:6
解釋:將 nums 拆分成兩個子數組:[1,2], [1,2,1] 。
[1,2] 的重要性是 2 + (0) = 2 。
[1,2,1] 的重要性是 2 + (2) = 4 。
拆分的代價是 2 + 4 = 6 ,可以證明這是所有可行的拆分方案中的最小代價。
示例 3:

輸入:nums = [1,2,1,2,1], k = 5
輸出:10
解釋:將 nums 拆分成一個子數組:[1,2,1,2,1].
[1,2,1,2,1] 的重要性是 5 + (3 + 2) = 10 。
拆分的代價是 10 ,可以證明這是所有可行的拆分方案中的最小代價。

提示:

1 <= nums.length <= 1000
0 <= nums[i] < nums.length
1 <= k <= 10^9

java代碼:

class Solution {public int minCost(int[] nums, int k) {int n = nums.length;int[] f = new int[n + 1];byte[] state = new byte[n];for (int i = 0; i < n; ++i) {Arrays.fill(state, (byte) 0);int unique = 0, mn = Integer.MAX_VALUE;for (int j = i; j >= 0; --j) {int x = nums[j];if (state[x] == 0) { // 首次出現state[x] = 1;++unique;} else if (state[x] == 1) { // 不再唯一state[x] = 2;--unique;}mn = Math.min(mn, f[j] - unique);}f[i + 1] = k + mn;}return f[n] + n;}
}

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

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

相關文章

一站式自動化測試平臺-Autotestplat

3.1 自動化平臺開發方案 3.1.1 功能需求 3.1.3 開發時間計劃 如果是剛入門、但有一點代碼基礎的測試人員&#xff0c;大概 3 個月能做出演示版(Demo)進行自動化測試&#xff0c;6 個月內勝任開展工作中項目的自動化測試。 如果是有自動化測試基礎的測試人員&#xff0c;大概 …

python序列化反序列化和異常處理筆記

迭代器 迭代是訪問集合元素的一種方式。迭代器是一個可以記住遍歷的位置的對象。迭代器對象從集合的第一個元素開始訪問&#xff0c;直到所有的元素被訪問完結束。迭代器只能往前不會后退。 1. 可迭代對象 我們已經知道可以對list、tuple、str等類型的數據使用for...in...的…

面試熱題(數組中的第K個最大元素)

給定整數數組 nums 和整數 k&#xff0c;請返回數組中第 k 個最大的元素。 請注意&#xff0c;你需要找的是數組排序后的第 k 個最大的元素&#xff0c;而不是第 k 個不同的元素。 輸入: [3,2,1,5,6,4] 和 k 2 輸出: 5提到數組中最大元素&#xff0c;我們往往想到就是先給數組…

判斷自己網絡所在的NAT類型

文章目錄 各NAT類型介紹軟件準備流程 各NAT類型介紹 NAT0: OpenInternet&#xff0c;沒有經過NAT地址轉換&#xff0c;公網IP NAT1: Full Cone NAT&#xff0c;動態家寬可以達到最優的狀態&#xff0c;外網設備可以主動發信息給NAT1網絡內的設備。 NAT2: Address-Restricted C…

什么是JavaScript中的柯里化(Currying)和偏函數應用(Partial Application)?它們在JavaScript中有哪些應用場景?

1、什么是JavaScript中的柯里化(Currying)和偏函數應用(Partial Application)&#xff1f;它們在JavaScript中有哪些應用場景&#xff1f; 柯里化&#xff08;Currying&#xff09;和偏函數應用&#xff08;Partial Application&#xff09;是函數式編程中的兩個重要概念&…

Mybatis 源碼 ④ :TypeHandler

文章目錄 一、前言二、DefaultParameterHandler1. DefaultParameterHandler#setParameters1.1 UnknownTypeHandler1.2 自定義 TypeHandler 三、DefaultResultSetHandler1. hasNestedResultMaps2. handleRowValuesForNestedResultMap2.1 resolveDiscriminatedResultMap2.2 creat…

K8S系列二:實戰入門

寫在前面 本文是K8S系列第二篇&#xff0c;主要面向對K8S新手同學&#xff0c;閱讀本文需要讀者對K8S的基本概念&#xff0c;比如Pod、Deployment、Service、Namespace等基礎概念有所了解。尚且不熟悉的同學推薦先閱讀本系列的第一篇文章&#xff1a;《K8S系列一&#xff1a;概…

遠程控制醫療行業應用解析:如何滿足醫院合規需求?

遠程控制醫療行業應用解析&#xff1a;如何滿足醫院合規需求&#xff1f; 作為一個起源于IT行業的技術&#xff0c;以遠程桌面為基礎的遠程控制技術目前在醫療領域也已經有了比較廣闊的應用前景&#xff0c;尤其是在醫療數字化系統/設備的遠程運維場景&#xff0c;已經有了一些…

如何正確下載tomcat???

親愛的小伙伴&#xff0c;千萬別再去找下網站下載啦&#xff0c;這樣詪容易攜帶病毒。 我們去官方網址下載。 Apache Tomcat - Welcome! 最后下載解壓即可。。。

正則表達式學習詳解

正則表達式 正則表達式&#xff08;Regular Expression&#xff09;&#xff0c;通常簡稱為正則或正則表達式&#xff0c;是一種用于描述字符串模式的工具。它是由一系列字符和特殊字符組成的字符串&#xff0c;用于定義搜索模式或進行字符串匹配、替換、提取等操作。 正則表…

2024軟考系統架構設計師論文寫作要點

一、寫作注意事項 系統架構設計師的論文題目對于考生來說&#xff0c;是相對較難的題目。一方面&#xff0c;考生需要掌握論文題目中的系統架構設計的專業知識;另一方面&#xff0c;論文的撰寫需要結合考生自身的項目經歷。因此&#xff0c;如何將自己的項目經歷和專業知識有機…

SQL server中substring 的用法

一&#xff1a;substring函數是SQL中截取字段數據中的其中一部分 --列&#xff1a;提取abdcsef中的abc數據&#xff0c;使用substring實現select substring(abdcsef,1,3) --‘1’表示截取的起始位置是從第一個字符開始,‘3’表示截取后得到的字符串長度為3個字符 二&#xff1…

React源碼解析18(7)------ 實現事件機制(onClick事件)

摘要 在上一篇中&#xff0c;我們實現了useState的hook&#xff0c;但由于沒有實現事件機制&#xff0c;所以我們只能將setState掛載在window上。 而這一篇主要就是來實現事件系統&#xff0c;從而實現通過點擊事件進行setState。 而在React中&#xff0c;雖然我們是將事件綁…

前后端分離------后端創建筆記(07)表單驗證

1、我輸入數據&#xff0c;然后關閉&#xff0c;重新打開會發現殘存的數據仍然保留著 2、點了這個x號&#xff0c;數據就全部被清理了 3、點這三個地方&#xff0c;數據全部都清理掉 4、這里先寫一個方法 4.1 定義一個方法 4.2 這里表單的數據在哪里&#xff0c;就是這個 4.3 …

在 Linux 中使用 cp 命令

cp 命令是 Linux 中一個重要的命令&#xff0c;你可能經常會用到它。 正如名稱所示&#xff0c;cp 代表 復制copy&#xff0c;它被用于 在 Linux 命令行中復制文件和目錄。 這是一個相對簡單的命令&#xff0c;只有幾個選項&#xff0c;但你仍有必要深入了解它。 在展示 cp …

VLLM推理流程梳理

0x0. 前言 本文在對VLLM進行解析時只關注單卡情況&#xff0c;忽略基于ray做分布式推理的所有代碼。 0x1. 運行流程梳理 先從使用VLLM調用opt-125M模型進行推理的腳本看起&#xff1a; from vllm import LLM, SamplingParams# Sample prompts. prompts ["Hello, my n…

二次封裝element-plus上傳組件,提供校驗、回顯等功能

二次封裝element-plus上傳組件 0 相關介紹1 效果展示2 組件主體3 視頻組件4 Demo 0 相關介紹 基于element-plus框架&#xff0c;視頻播放器使用西瓜視頻播放器組件 相關能力 提供圖片、音頻、視頻的預覽功能提供是否為空、文件類型、文件大小、文件數量、圖片寬高校驗提供圖片…

el-table實現懶加載(el-table-infinite-scroll)

2023.8.15今天我學習了用el-table對大量的數據進行懶加載。 效果如下&#xff1a; 1.首先安裝&#xff1a; npm install --save el-table-infinite-scroll2 2.全局引入&#xff1a; import ElTableInfiniteScroll from "el-table-infinite-scroll";// 懶加載 V…

clion2020.3配置clang-format

標題clion 啟用clang-format 文件->設置->編輯器->代碼樣式. 為了保持原有代碼風格不變&#xff0c;可以把原始的配置風格先導出&#xff0c;最好直接保存到自己的工程下&#xff0c;.clang-format是隱藏文件&#xff0c;需要用ctrlH才能看到 文件->設置->編輯…

SpringBoot復習:(45)@Component定義的bean會被@Bean定義的同名的bean覆蓋

有同名的bean需要配置&#xff1a; spring.main.allow-bean-definition-overridingtrue 否則報錯。 package cn.edu.tju.component;import org.springframework.stereotype.Component;Component public class Person {private String name;private int age;{this.name "…