LeetCode 解題思路 45(分割等和子集、最長有效括號)

在這里插入圖片描述

解題思路:

  1. dp 數組的含義: 在數組中是否存在一個子集,其和為 i。
  2. 遞推公式: dp[i] |= dp[i - num]。
  3. dp 數組初始化: dp[0] = true。
  4. 遍歷順序: 從大到小去遍歷,從 i = target 開始,直到 i = num。確保每個數只用一次。
  5. 打印 dp 數組

Java代碼:

class Solution {public boolean canPartition(int[] nums) {int sum = 0;for (int num : nums)sum += num;if (sum % 2 != 0)return false;int target = sum / 2;boolean[] dp = new boolean[target + 1];dp[0] = true;for (int num : nums) {for (int i = target; i >= num; i--) {dp[i] |= dp[i - num];}}return dp[target];}
}

復雜度分析:

  • 時間復雜度: O(n * target)。
  • 空間復雜度: O(target)。
    在這里插入圖片描述

解題思路:

可以使用棧來解決這個問題。核心思想是利用棧來跟蹤未匹配的括號的索引。初始化時,棧中壓入一個基準索引 -1,用于后續計算有效子串的長度。遍歷字符串時:

  • 遇到左括號 ‘(’,將其索引壓入棧中。
  • 遇到右括號 ‘)’,彈出棧頂元素。此時:
  • 若棧為空,說明當前右括號無匹配,將當前索引壓入棧作為新基準。
  • 若棧不為空,當前有效子串長度為當前索引與棧頂元素的差值,更新最大值。

此方法確保每次彈出棧頂后,棧頂元素即為最近未匹配的左括號或基準點,從而快速計算有效長度。

Java代碼:

public class Solution {public int longestValidParentheses(String s) {Deque<Integer> stack = new ArrayDeque<>();stack.push(-1);int maxLen = 0;for (int i = 0; i < s.length(); i++) {char c = s.charAt(i);if (c == '(') {stack.push(i);} else {stack.pop();if (stack.isEmpty()) {stack.push(i);} else {maxLen = Math.max(maxLen, i - stack.peek());}}}return maxLen;}
}

復雜度分析:

  • 時間復雜度: O(n)。
  • 空間復雜度: O(n)。

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

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

相關文章

電影感戶外啞光人像自拍攝影Lr調色預設,手機濾鏡PS+Lightroom預設下載!

調色詳情 電影感戶外啞光人像自拍攝影 Lr 調色&#xff0c;是借助 Lightroom 軟件&#xff0c;針對戶外環境下拍攝的人像自拍進行后期處理。旨在模擬電影畫面的氛圍與質感&#xff0c;通過調色賦予照片獨特的藝術氣息。強調打造啞光效果&#xff0c;使畫面色彩不過于濃烈刺眼&a…

使用 NV?Ingest、Unstructured 和 Elasticsearch 處理非結構化數據

作者&#xff1a;來自 Elastic Ajay Krishnan Gopalan 了解如何使用 NV-Ingest、Unstructured Platform 和 Elasticsearch 為 RAG 應用構建可擴展的非結構化文檔數據管道。 Elasticsearch 原生集成了行業領先的生成式 AI 工具和提供商。查看我們的網絡研討會&#xff0c;了解如…

Android 13 使能user版本進recovery

在 debug 版本上&#xff0c;可以在關機狀態下&#xff0c;同時按 電源鍵 和 音量加鍵 進 recovery 。 user 版本上不行。 參考 使用 build 變體 debug 版本和 user 版本的差別之一就是 ro.debuggable 屬性不同。 順著這個思路追蹤&#xff0c;找到 bootable/recovery/reco…

每日算法刷題計劃

這是我每天堅持刷算法題的倉庫&#xff0c;每天刷1-3道&#xff0c;時間30-40min&#xff0c;加油! 目前考慮leetcode洛谷形式&#xff0c;c和python3語言&#xff0c;leetcode主要學核心思想&#xff0c;洛谷學會輸入輸出格式 每日打卡:markdowncsdn打卡 刷題策略: 按分類刷…

紅黑樹():

1. 紅黑樹&#xff1a; 紅黑樹從根節點開始的最長的路徑不會超過最短路徑的2倍。 紅黑樹的話&#xff0c;他的結點的分布沒有我們的AVL樹的結點的分布均衡&#xff0c;但是效率也不錯&#xff0c;AVL樹的結點分布的那么均勻&#xff0c;其實也是在進行了旋轉&#xff0c;付出了…

【AI智能推薦系統】第六篇:隱私保護與聯邦學習在推薦系統中的平衡之道

第六篇:隱私保護與聯邦學習在推薦系統中的平衡之道 提示語:?? “數據不出域,推薦更精準!深度揭秘騰訊、螞蟻集團如何用聯邦學習打造合規推薦系統,隱私計算技術全景解析與工業級實現方案!” 目錄 隱私保護的行業挑戰隱私計算技術體系 2.1 聯邦學習基礎架構2.2 差分隱私…

【Qt/C++】深入理解 Lambda 表達式與 `mutable` 關鍵字的使用

【Qt/C】深入理解 Lambda 表達式與 mutable 關鍵字的使用 在 Qt 開發中&#xff0c;我們常常會用到 lambda 表達式來編寫簡潔的槽函數。今天通過一個實際代碼示例&#xff0c;詳細講解 lambda 的語法、變量捕獲方式&#xff0c;特別是 mutable 的作用。 示例代碼 QPushButto…

記錄 ubuntu 安裝中文語言出現 software database is broken

搜索出來的結果是 sudo apt-get install language-pack-zh-han* 然而,無效,最后手動安裝如下 apt install language-pack-zh-hans apt install language-pack-zh-hans-base apt install language-pack-gnome-zh-hans apt install fonts-arphic-uming apt install libreoffic…

[虛幻官方教程學習筆記]深入理解實時渲染(An In-Depth Look at Real-Time Rendering)

原英文教程地址深入理解實時渲染&#xff08;An In-Depth Look at Real-Time Rendering&#xff09; 文章目錄 1.Intro to An In-Depth Look at Real-Time RenderingCPU VS GPUDeferred VS Forward 2. Before Rendering and OcclusionCulling計算的步驟使用console command:fre…

Linux進程間信號

目錄 信號入門 生活角度中的信號 技術應用角度的信號 信號的發送與記錄 信號處理常見方式概述 產生信號 通過終端按鍵產生 通過系統函數向進程發信號 由軟件條件產生信號 由硬件異常產生信號 阻塞信號 信號其他相關常見概念 在內核中的表示 sigset_t 信號集操作…

Git簡介和發展

Git 簡介 Git是一個開源的分布式版本控制系統&#xff0c;跨平臺&#xff0c;支持Windows、Linux、MacOS。主要是用于項目的版本管理&#xff0c;是由林納斯托瓦茲(Linux Torvalds)在2005年為Linux內核開發而創建。 起因 在2002年至2005年間&#xff0c;Linux內核開發團隊使…

Perspective,數據可視化的超級引擎!

Perspective 是一個強大的交互式數據分析和可視化庫&#xff0c;它允許你創建高度可配置的報告、儀表板、筆記本和應用程序。給用戶提供了一個新的視角來看待數據。 Stars 數9125Forks 數1217 主要特點 高效流式查詢引擎&#xff1a;Perspective使用C編寫&#xff0c;并編譯為…

MySQL COUNT(*) 查詢優化詳解!

目錄 前言1. COUNT(*) 為什么慢&#xff1f;—— InnoDB 的“計數煩惱” &#x1f914;2. MySQL 執行 COUNT(*) 的方式 (InnoDB)3. COUNT(*) 優化策略&#xff1a;快&#xff01;準&#xff01;狠&#xff01;策略一&#xff1a;利用索引優化帶 WHERE 子句的 COUNT(*) (最常見且…

如何在postman使用時間戳

1. 使用 Pre-request Script 動態轉換? 在發送請求前&#xff0c;將日期字符串轉為時間戳并存儲為環境變量/全局變量。 ?示例代碼? // 將日期字符串&#xff08;如 "2023-10-01"&#xff09;轉為時間戳&#xff08;毫秒&#xff09; const dateString "2…

嵌入式學習筆記 - 運算放大器的共模抑制比

一 定義 共模抑制比&#xff08;Common Mode Rejection Ratio, ?CMRR?&#xff09;是衡量差分放大器&#xff08;或差分電路&#xff09;抑制共模信號能力的關鍵指標。它在電子工程中尤為重要&#xff0c;特別是在需要處理微弱信號或對抗環境噪聲的場景中。 核心概念 ?共…

成龍電影中的三菱汽車

帕杰羅、 Lancer Evolution、 3000GT Mitsubishi Lancer Evo ll 1995 附錄 Mercedes-Benz 280SL&#xff08;W113&#xff09;&#xff0c;俗稱“Pagoda”&#xff08;帕格達&#xff09;

Spring 項目無法連接 MySQL:Nacos 配置誤區排查與解決

在開發過程中&#xff0c;我們使用 Nacos 來管理 Spring Boot 項目的配置&#xff0c;其中包括數據庫連接配置。然而&#xff0c;在實際操作中&#xff0c;由于一些概念的混淆&#xff0c;我們遇到了一些連接問題。本文將分享我的故障排查過程&#xff0c;幫助大家避免類似的錯…

LabVIEW與 IMAQ Vision 機器視覺應用

在工業生產及諸多領域&#xff0c;精確高效的檢測至關重要。基于 LabVIEW 與 IMAQ Vision 的機器視覺應用&#xff0c;深入剖析其原理、系統構成、軟件設計及優勢&#xff0c;為相關領域工程師提供全面技術參考。 ? 一、技術原理 &#xff08;一&#xff09;機器視覺技術基礎…

【STM32 學習筆記】USART串口

注意&#xff1a;在串口助手的接收模式中有文本模式和HEX模式兩種模式&#xff0c;那么它們有什么區別&#xff1f; ??文本模式和Hex模式是兩種不同的文件編輯或瀏覽模式&#xff0c;不是完全相同的概念。文本模式通常是指以ASCII編碼格式表示文本文件的編輯或瀏覽模式。在文…

【WPS】怎么解決“word的復制表格”粘貼到“excel的單元格”變多行單元格的問題

把 word文檔復制表格到這個excel表格上面的話&#xff0c;會出現由單個單元格變成多行單元格的情況。 現在&#xff0c;就這個問題怎么解決&#xff0c;提出了一個方案&#xff0c;就是先查找是什么導致了這個換行&#xff0c;然后再將換行的這個字符進行一個整體的替換&#x…