LeetCode 0132.分割回文串 II:動態規劃

【LetMeFly】132.分割回文串 II:動態規劃

力扣題目鏈接:https://leetcode.cn/problems/palindrome-partitioning-ii/

給你一個字符串 s,請你將 s 分割成一些子串,使每個子串都是回文串。

返回符合要求的 最少分割次數

?

示例 1:

輸入:s = "aab"
輸出:1
解釋:只需一次分割就可將?s 分割成 ["aa","b"] 這樣兩個回文子串。

示例 2:

輸入:s = "a"
輸出:0

示例 3:

輸入:s = "ab"
輸出:1

?

提示:

  • 1 <= s.length <= 2000
  • s 僅由小寫英文字母組成

解題方法:動態規劃

整個過程分為兩步:預處理 和 動態規劃

動態規劃:

使用數組 d p dp dp,其中 d p [ i ] dp[i] dp[i]代表使得子字符串 0... i 0...i 0...i為回文字符串組合的最小分割次數,那么 d p [ l e n ( s ) ? 1 ] dp[len(s) - 1] dp[len(s)?1]即為答案。

  • 如果 0... i 0...i 0...i直接為回文字符串,那么分割次數為0。

  • 否則,對于 j ∈ 0... i ? 1 j\in 0...i-1 j0...i?1,如果 j + 1.. i j + 1..i j+1..i是回文字符串,那么有 d p [ i ] = m i n ( d p [ j ] + 1 ) dp[i] = min(dp[j] + 1) dp[i]=min(dp[j]+1)

預處理:

有沒有什么辦法 O ( 1 ) O(1) O(1)時間內快速判斷下標從 i i i j j j的子字符串是否為回文字符串?有,我們可以先使用 O ( n 2 ) O(n^2) O(n2)復雜度的時間預處理。使用 i s O k [ i ] [ j ] isOk[i][j] isOk[i][j]表示子字符串 i . . . j i...j i...j是否為回文字符串:

  • 如果子字符串為空或者長度為1,則是回文字符串( i ≥ j i \geq j ij)
  • 否則:是回文字符串當且僅當 s [ i ] = = s [ j ] AND? i s O k [ i + 1 ] [ j ? 1 ] s[i] == s[j] \text{ AND }isOk[i + 1][j - 1] s[i]==s[j]?AND?isOk[i+1][j?1]

時空復雜度分析

  • 時間復雜度 O ( n 2 ) O(n^2) O(n2),預處理和動態規劃的時間復雜度都是 O ( n 2 ) O(n^2) O(n2)。其中 n = l e n ( s ) n = len(s) n=len(s)
  • 空間復雜度 O ( n 2 ) O(n^2) O(n2)

AC代碼

C++
/** @Author: LetMeFly* @Date: 2025-03-02 12:02:45* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:26:06*/
class Solution {
public:int minCut(string s) {vector<vector<bool>> isOk(s.size(), vector<bool>(s.size(), true));for (int i = s.size() - 1; i >= 0; i--) {for (int j = i + 1; j < s.size(); j++) {isOk[i][j] = s[i] == s[j] && isOk[i + 1][j - 1];}}vector<int> dp(s.size(), 1000000);for (int i = 0; i < s.size(); i++) {if (isOk[0][i]) {dp[i] = 0;continue;}for (int j = 0; j < i; j++) {if (isOk[j + 1][i]) {dp[i] = min(dp[i], dp[j] + 1);}}}return dp.back();}
};
Python
'''
Author: LetMeFly
Date: 2025-03-02 12:26:57
LastEditors: LetMeFly.xyz
LastEditTime: 2025-03-02 12:33:40
'''
class Solution:def minCut(self, s: str) -> int:isOk = [[True] * len(s) for _ in range(len(s))]for i in range(len(s) - 1, -1, -1):for j in range(i + 1, len(s)):isOk[i][j] = s[i] == s[j] and isOk[i + 1][j - 1]dp = [100000] * len(s)for i in range(len(s)):if isOk[0][i]:dp[i] = 0continuefor j in range(i):if isOk[j + 1][i]:dp[i] = min(dp[i], dp[j] + 1)return dp[-1]
Java
/** @Author: LetMeFly* @Date: 2025-03-02 12:34:31* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:38:17*/
class Solution {public int minCut(String s) {boolean[][] isOk = new boolean[s.length()][s.length()];for (int i = 0; i < s.length(); i++) {for (int j = 0; j < s.length(); j++) {isOk[i][j] = true;}}for (int i = s.length() - 1; i >= 0; i--) {for (int j = i + 1; j < s.length(); j++) {isOk[i][j] = s.charAt(i) == s.charAt(j) && isOk[i + 1][j - 1];}}int[] dp = new int[s.length()];for (int i = 0; i < s.length(); i++) {dp[i] = 100000;}for (int i = 0; i < s.length(); i++) {if (isOk[0][i]) {dp[i] = 0;continue;}for (int j = 0; j < i; j++) {if (isOk[j + 1][i]) {dp[i] = Math.min(dp[i], dp[j] + 1);}}}return dp[dp.length - 1];}
}
Go
/** @Author: LetMeFly* @Date: 2025-03-02 12:39:13* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-02 12:43:12*/
package mainfunc minCut(s string) int {isOk := make([][]bool, len(s))for i, _ := range isOk {isOk[i] = make([]bool, len(s))for j, _ := range isOk[i] {isOk[i][j] = true}}for i := len(s) - 1; i >= 0; i-- {for j := i + 1; j < len(s); j++ {isOk[i][j] = s[i] == s[j] && isOk[i + 1][j - 1]}}dp := make([]int, len(s))for i, _ := range dp {dp[i] = 100000}for i := 0; i < len(dp); i++ {if isOk[0][i] {dp[i] = 0continue}for j := 0; j < i; j++ {if isOk[j + 1][i] {dp[i] = min(dp[i], dp[j] + 1)}}}return dp[len(dp) - 1]
}

同步發文于CSDN和我的個人博客,原創不易,轉載經作者同意后請附上原文鏈接哦~

千篇源碼題解已開源

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

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

相關文章

iOS 實現UIButton自動化點擊埋點

思路&#xff1a;我們HOOK UIControl的 addtarget:action:forControlEvents方法&#xff0c;交換UIControl的 addtarget:action:forControlEvents 方法的實現&#xff0c; 在交換的方法中添加原來響應的同時&#xff0c;再添加一個埋點響應&#xff0c;該響應方法實現了點擊埋點…

C++藍橋杯基礎篇(六)

片頭 嗨~小伙伴們&#xff0c;大家好&#xff01;今天我們來一起學習藍橋杯基礎篇&#xff08;六&#xff09;&#xff0c;練習相關的數組習題&#xff0c;準備好了嗎&#xff1f;咱們開始咯&#xff01; 第1題 數組的左方區域 這道題&#xff0c;實質上是找規律&#xff0c;…

git -學習筆記

目錄 基本操作語法 設置用戶和郵箱 版本回退 工作區和暫存區 撤銷修改 刪除與恢復 一工作區刪除了&#xff0c;但是暫存區沒刪除 二工作區誤刪了&#xff0c;暫存區還有 github-Git 連接 報錯解決-push遠程倉庫被拒絕 遠程庫 分支 分支沖突 儲藏分支 回到當前分…

Windows本地Docker+Open-WebUI部署DeepSeek

最近想在自己的電腦本地部署一下DeepSeek試試&#xff0c;由于不希望污染電腦的Windows環境&#xff0c;所以在wsl中安裝了ollama&#xff0c;使用ollama拉取DeepSeek模型。然后在Windows中安裝了Docker Desktop&#xff0c;在Docker中部署了Open-WebUI&#xff0c;最后再在Ope…

力扣785. 判斷二分圖

力扣785. 判斷二分圖 題目 題目解析及思路 題目要求將所有節點分成兩部分&#xff0c;每條邊的兩個端點都必須在不同集合中 二分圖&#xff1a;BFS/DFS/并查集 因為圖不一定聯通&#xff0c;所以枚舉所有點都做bfs(如果沒聯通的話) 代碼 class Solution { public:bool is…

springboot之集成Elasticsearch

目錄 二、Elasticsearch 是什么&#xff1f;三、Elasticsearch 安裝四、Springboot 集成 Elasticsearch 的方式五、創建項目集成 Elasticsearch 2.創建 Spring Initializr 項目 es &#xff08;3&#xff09;.新建實體類 User&#xff08;4&#xff09;.新建 dao 接口類 UserR…

[Lc滑動窗口_1] 長度最小的數組 | 無重復字符的最長子串 | 最大連續1的個數 III | 將 x 減到 0 的最小操作數

目錄 1. 長度最小的字數組 題解 代碼 ?2.無重復字符的最長子串 題解 代碼 3.最大連續1的個數 III 題解 代碼 4.將 x 減到 0 的最小操作數 題解 代碼 1. 長度最小的字數組 題目鏈接&#xff1a;209.長度最小的字數組 題目分析: 給定一個含有 n 個 正整數 的數組…

數據集筆記:新加坡 地鐵(MRT)和輕軌(LRT)票價

數據連接 data.gov.sg 2024 年 12 月 28 日起生效的新加坡地鐵票價 該數據集包含 MRT 和 LRT 票價的信息&#xff0c;包括&#xff1a; 票價類型&#xff08;Fare Type&#xff09;&#xff1a;成人票、學生票、老年人票、殘障人士票等。適用時間&#xff08;Applicable Tim…

湘潭大學計算機復試詳細攻略(調劑)

一&#xff0c;寫在前面的話 ① 首先&#xff0c;能完成考試初試來到這里的都是勇士。不管結果如何&#xff0c;不管成績如何。我都在這里真心的祝福你以后一帆風順。 ② 目前學歷貶值嚴重&#xff0c;如果是成績不理想的話&#xff0c;我建議能工作就去工作&#xff0c;工作不…

【前端基礎】Day 3 CSS-2

目錄 1. Emmet語法 1.1 快速生成HTML結構語法 1.2 快速生成CSS樣式語法 2. CSS的復合選擇器 2.1 后代選擇器 2.2 子選擇器 2.3 并集選擇器 2.4 偽類選擇器 2.4.1 鏈接偽類選擇器 2.4.2 focus偽類選擇器 2.5 復合選擇器總結 3. CSS的元素顯示模式 3.1 什么是元素顯示…

不同數據類型在數據庫和編程語言之間的對應關系表

不同數據類型在數據庫和編程語言之間的對應關系表 MySql 與 C# MySqlC#varcharstringbigintlongbigint unsignedulongintintint unsigneduintsmallintshortsmallint unsignedushortVARCHAR(36)GuidsmalldatetimeDateTimedateDateTimedatetimeDateTimetimestampDateTimefloatf…

RabbitMQ操作實戰

1.RabbitMQ安裝 RabbitMQ Windows 安裝、配置、使用 - 小白教程-騰訊云開發者社區-騰訊云下載erlang&#xff1a;http://www.erlang.org/downloads/https://cloud.tencent.com/developer/article/2192340 Windows 10安裝RabbitMQ及延時消息插件rabbitmq_delayed_message_exch…

DeepSeek教unity------UI元素長按響應

主要功能說明&#xff1a; ?長按檢測&#xff1a;通過記錄指針按下的時間&#xff0c;判斷是否達到 longClickTime&#xff0c;從而觸發長按事件。?狀態管理&#xff1a;使用 StateEnum 枚舉管理點擊項的當前狀態&#xff08;未按下、按下等待長按、長按已觸發&#xff09;。…

【北京迅為】itop-3568 開發板openharmony鴻蒙燒寫及測試-第2章OpenHarmony v3.2-Beta4版本測試

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工藝&#xff0c;搭載一顆四核Cortex-A55處理器和Mali G52 2EE 圖形處理器。RK3568 支持4K 解碼和 1080P 編碼&#xff0c;支持SATA/PCIE/USB3.0 外圍接口。RK3568內置獨立NPU&#xff0c;可用于輕量級人工…

stm32hal庫尋跡+藍牙智能車(STM32F103C8T6)

簡介: 這個小車的芯片是STM32F103C8T6&#xff0c;其他的芯片也可以照貓畫虎,基本配置差不多,要注意的就是,管腳復用,管腳的特殊功能,(這點不用擔心,hal庫每個管腳的功能都會給你羅列,很方便的.)由于我做的比較簡單,只是用到了幾個簡單外設.主要是由帶霍爾編碼器電機的車模,電機…

SQL命令詳解之操作數據庫

操作數據庫 SQL是用于管理和操作關系型數據庫的標準語言。數據庫操作是SQL的核心功能之一&#xff0c;主要用于創建、修改和刪除數據庫對象&#xff0c;如數據庫、表、視圖和索引等。以下是SQL中常見的數據庫操作命令及其功能簡介&#xff1a; 1. 查詢數據庫 查詢所有的數據庫…

Go紅隊開發—編解碼工具

文章目錄 開啟一個項目編解碼工具開發Dongle包Base64編解碼摩斯密碼URL加解密AES加解密 MD5碰撞工具開發 開啟一個項目 這作為補充內容&#xff0c;可忽略直接看下面的編解碼&#xff1a; 一開始用就按照下面的步驟即可 1.創建一個文件夾&#xff0c;你自己定義名字(建議只用…

Starrocks入門(二)

1、背景&#xff1a;考慮到Starrocks入門這篇文章&#xff0c;安裝的是3.0.1版本的SR&#xff0c;參考&#xff1a;Starrocks入門-CSDN博客 但是官網的文檔&#xff0c;沒有對應3.0.x版本的資料&#xff0c;卻有3.2或者3.3或者3.4或者3.1或者2.5版本的資料&#xff0c;不要用較…

工程化與框架系列(10)--微前端架構

微前端架構 &#x1f3d7;? 微前端是一種將前端應用分解成更小、更易管理的獨立部分的架構模式。本文將詳細介紹微前端的核心概念、實現方案和最佳實踐。 微前端概述 &#x1f31f; &#x1f4a1; 小知識&#xff1a;微前端的核心理念是將前端應用分解成一系列獨立部署、松耦…

SwiftUI之狀態管理全解析

文章目錄 引言一、`@State`1.1 基本概念1.2 初始化與默認值1.3 注意事項二、`@Binding`2.1 基本概念2.2 初始化與使用2.3 注意事項三、`@ObservedObject`3.1 基本概念3.2 初始化與使用3.3 注意事項四、`@EnvironmentObject`4.1 基本概念4.2 初始化與使用4.3 注意事項五、`@Stat…