代碼隨想錄算法訓練營Day60 | 84.柱狀圖中最大的矩形 | Python | 個人記錄向

注:今天是代碼隨想錄訓練營的最后一天啦!!!

本文目錄

  • 84.柱狀圖中最大的矩形
    • 做題
    • 看文章
  • 以往忽略的知識點小結
  • 個人體會

84.柱狀圖中最大的矩形

代碼隨想錄:84.柱狀圖中最大的矩形
Leetcode:84.柱狀圖中最大的矩形

做題

無思路。

看文章

與 42. 接雨水 很像,42. 接雨水 是找每個柱子左右兩邊第一個大于該柱子高度的柱子,而本題是找每個柱子左右兩邊第一個小于該柱子的柱子

舉例說明求解:[2, 1, 5, 6, 2, 3]。以1為基準,左右都沒有比1小的,所以1可以向左右拓展到底,即高為1、寬為6。以5為基準,左邊1<5,右邊2<5,所以5可以向左拓展到1(開區間),向右拓展到2(開區間),即高為5、寬為2。

在此基礎上結合單調棧,具體可看視頻。

# 單調棧
class Solution:def largestRectangleArea(self, heights: List[int]) -> int:# Monotonic Stack'''找每個柱子左右側的第一個高度值小于該柱子的柱子單調棧:棧頂到棧底:從大到小(每插入一個新的小數值時,都要彈出先前的大數值)棧頂,棧頂的下一個元素,即將入棧的元素:這三個元素組成了最大面積的高度和寬度情況一:當前遍歷的元素heights[i]大于棧頂元素的情況情況二:當前遍歷的元素heights[i]等于棧頂元素的情況情況三:當前遍歷的元素heights[i]小于棧頂元素的情況'''# 輸入數組首尾各補上一個0(與42.接雨水不同的是,本題原首尾的兩個柱子可以作為核心柱進行最大面積嘗試heights.insert(0, 0)heights.append(0)stack = [0]result = 0for i in range(1, len(heights)):# 情況一if heights[i] > heights[stack[-1]]:stack.append(i)# 情況二elif heights[i] == heights[stack[-1]]:stack.pop()stack.append(i)# 情況三else:# 拋出所有較高的柱子while stack and heights[i] < heights[stack[-1]]:# 棧頂就是中間的柱子,主心骨mid_index = stack[-1]stack.pop()if stack:left_index = stack[-1]right_index = iwidth = right_index - left_index - 1height = heights[mid_index]result = max(result, width * height)stack.append(i)return result

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

以往忽略的知識點小結

  • 單調棧的思路還是不熟

個人體會

完成時間:1h30min。
心得:84.柱狀圖中最大的矩形 與 42.接雨水 思路差不多,但為什么怎么做,還需要多琢磨琢磨。很感嘆的是,算法訓練營今天就結營了,感覺時間飛快。

?

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

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

相關文章

解決使用Python檢查本地網絡中運行的Web服務器的問題

如果我們要檢查本地網絡中運行的 Web 服務器&#xff0c;可以使用 Python 的 socket 模塊來進行網絡連接測試。以下是一個簡單的示例代碼&#xff0c;演示如何檢查本地網絡中運行的 Web 服務器&#xff1a; 1、問題背景 在學習如何使用 Python 時&#xff0c;一位用戶希望編寫…

從零開始:騰訊云輕量應用服務器上部署MaxKB項目(基于LLM大語言模型的知識庫問答系統)

使用騰訊云輕量應用服務器部署和使用MaxKB項目 前言 一&#xff0c; MaxKB介紹 MaxKB是基于LLM大語言模型的知識庫問答系統&#xff0c;旨在成為企業的最強大腦。它支持開箱即用&#xff0c;無縫嵌入到第三方業務系統&#xff0c;并提供多模型支持&#xff0c;包括主流大模型…

我們如何收到衛星信號?(導航電文,載波與測距碼)

衛星信號 在介紹所有衛星信號之前&#xff0c;首先要明確一些概念&#xff1a; 所有的衛星信號&#xff0c;都是一段電磁波&#xff0c;用戶接收的&#xff0c;也是一段電磁波。 但是我們認知中的電磁波&#xff0c;就是一段波&#xff0c;就像我們打出去的交一樣&#xff0c…

【UML用戶指南】-03-UML的14種圖

目錄 1、結構圖 1、類圖&#xff08;class diagram&#xff09; 2、對象圖&#xff08;object diagram&#xff09; 3、構件圖 &#xff08;component diagram&#xff09; 4、組合結構圖 5、包圖&#xff08;package diagram&#xff09; 6、部署圖&#xff08;deploym…

Android輸入法IME(二)

2. IME初始化啟動流程 2.1. IME客戶端&#xff08;IMM&#xff09;初始化流程 涉及代碼文件路徑&#xff1a; frameworks/base/core/java/android/view/ViewRootImpl.java frameworks/base/core/java/android/view/WindowManagerGlobal.java frameworks/base/core/java/andro…

【kubernetes】k8s的面試寶典,等你來拿哦

目錄 一、pod的生命周期 二、創建 pod 的工作流程 三、ingres 有哪些組件并且描述出組件作用 &#xff1f; 四、ingress 的工作原理 五、ingress 暴露服務的方式 六、pod 的組成 七、pod的本身性質&#xff08;pod的種類與說明&#xff09; 八、k8s命令 8.1在k8s中如何…

零基礎入門學習Python第二階04SQL詳解03

MySQL 新特性 JSON類型 很多開發者在使用關系型數據庫做數據持久化的時候&#xff0c;常常感到結構化的存儲缺乏靈活性&#xff0c;因為必須事先設計好所有的列以及對應的數據類型。在業務發展和變化的過程中&#xff0c;如果需要修改表結構&#xff0c;這絕對是比較麻煩和難…

AppStore搜索優化方法(ASO)

在競爭激烈的 App Store 中&#xff0c;如何讓你的應用脫穎而出&#xff0c;吸引更多用戶下載&#xff1f;其實從官方文檔描述中可以總結一些優化技巧&#xff0c;這是官方描述地址&#xff1a;搜索優化 – App Store – Apple Developer。通過官方描述我們可以總結到影響搜索結…

commander.js 入門指南:構建強大的命令行界面 (全網最全教程)

在Node.js的世界里&#xff0c;創建用戶友好的命令行界面&#xff08;CLI&#xff09;對于許多應用程序和工具來說至關重要。Commander.js 是一個廣受歡迎的 Node.js 包&#xff0c;它為開發者提供了一套簡潔而強大的 API&#xff0c;用于快速創建功能完備、用戶友好的命令行界…

如何用TCC方案輕松實現分布式事務一致性

本文作者:小米,一個熱愛技術分享的29歲程序員。如果你喜歡我的文章,歡迎關注我的微信公眾號“軟件求生”,獲取更多技術干貨! 哈嘍,大家好!我是小米,一個熱愛技術的活力小青年,今天要和大家分享的是一種在分布式系統中實現事務的一種經典方案——TCC(Try Confirm Canc…

【Ubuntu】超詳細安裝Ubuntu系統

鑒于有些小伙伴在安裝Ubuntu系統的時候遇到很多問題&#xff0c;因此打算編寫一篇記錄一下安裝Ubuntu系統的整個過程~互相學習&#xff01; 一、制作U盤啟動 準備一個大于8G以上的U盤&#xff0c;這里我使用的是16G的U盤下載UltraISO工具 網站地址&#xff1a;UltraISO準備Ub…

C++ Primer 第五版 第15章 面向對象程序設計

面向對象程序設計基于三個基本概念&#xff1a;數據抽象、繼承和動態綁定。 繼承和動態綁定對編寫程序有兩方面的影響&#xff1a;一是我們可以更容易地定義與其他類相似但不完全相同的新類&#xff1b;二是在使用這些彼此相似的類編寫程序時&#xff0c;我們可以在一定程度上…

HTML靜態網頁成品作業(HTML+CSS)—— 金寶貝兒童教育機構介紹網頁(2個頁面)

&#x1f389;不定期分享源碼&#xff0c;關注不丟失哦 文章目錄 一、作品介紹二、作品演示三、代碼目錄四、網站代碼HTML部分代碼 五、源碼獲取 一、作品介紹 &#x1f3f7;?本套采用HTMLCSS&#xff0c;未使用Javacsript代碼&#xff0c;共有2個頁面。 二、作品演示 三、代…

Stable diffusion prompts 使用語法、參數講解、插件安裝教程

Stable diffusion prompts 使用語法、參數講解、插件安裝教程 本文基于 Stable diffusion WebUI 進行講解&#xff08;安裝在 AutoDL 上&#xff0c;安裝在本地電腦上的也同樣適用本教程&#xff09;。 初始界面&#xff1a; 文件目錄結構&#xff1a; 上圖紅框中的 4 個文件…

requests模塊編寫漏洞檢測工具

#嘗試使用python登錄pikachu爆破模塊 #發送post數據包&#xff0c;包含用戶名密碼&#xff0c;對接受到的響應進行判斷&#xff0c;如何為登錄成功 #爆破密碼 with open(passwor.txt,r) as f: passwordf.readlines() for i in password: data {username: admin, password: i, …

數據結構——算法和算法效率的度量

目錄 一、引言 二、算法 1 算法的基本概念 2 算法的復雜度 2.1 時間復雜度 2.1.1 概念 2.1.2 大O的漸進表示 3 算法的空間復雜度 3.1 概念 3.2 實例 4 實例分析 5 結論 一、引言 大家在寫代碼的時候有沒有發現寫同樣功能的代碼有多種不同的寫法&#xff0c;而不同的代…

51種企業應用架構模式詳解

01 什么是企業應用 我的職業生涯專注于企業應用&#xff0c;因此&#xff0c;這里所談及的模式也都是關于企業應用的。&#xff08;企業應用還有一些其他的說法&#xff0c;如“信息系統”或更早期的“數據處理”。&#xff09;那么&#xff0c;這里的“企業應用”具體指的是什…

[原型資源分享]經典產品餓了么UI模版部件庫

?部件庫預覽鏈接&#xff1a;https://f13gm0.axshare.com 支持版本: Axrure RP 8 文件大小: 3MB 文檔內容介紹 基本部件&#xff1a;表單樣式&#xff1a;12款、數據樣式&#xff1a;10款、服務樣式&#xff1a;6款、導航&#xff1a;5款、業務組件&#xff1a;7款、 模板…

python把簡體中文轉換為繁體中文

Python 可以使用第三方庫來將簡體中文&#xff08;簡體中文&#xff09;轉換為繁體中文&#xff08;繁體中文&#xff09;。一個常用的庫是 opencc-python-reimplemented&#xff0c;它是 Open Chinese Convert (OpenCC) 的 Python 實現&#xff0c;OpenCC 是一個開源的中文簡繁…

MySQL之查詢性能優化(三)

查詢性能優化 重構查詢的方式 在優化有問題的查詢時&#xff0c;目標應該是找到一個更優的方法獲得實際需要的記過——而不是一定總是需要從MySQL獲取一模一樣的結果集。有時候&#xff0c;可以將查詢轉換一種寫法讓其返回一樣的結果&#xff0c;但是性能更好。但也可以通過修…