乘最多水的容器 | 算法 | 給定一個整數數組。有n條垂線。找出其中的兩條線,使得它們與 x 軸共同構成的容器可以容納最多的水。

在我們日常生活中,蓄水似乎是一個極為樸素的物理行為:兩堵墻之間,注入水,看誰能裝得更多。可如果換個角度,從算法的視角去看這個問題,它會變得怎樣?你是否意識到,這樣一個簡單的問題背后,隱藏著的是人類在面對“有限資源中尋找最優解”這一命題時,所展現出的智慧與思維模式?

圖片

一、從“裝水問題”談起:問題的提出與物理直覺

1.1 題目描述:算法問題的語義抽象

我們被給予一個整數數組?height,其每個元素代表一根垂直于 x 軸的線段的高度。第?i?條線段位于橫坐標?i?處。我們要從中選擇任意兩條線段,以 x 軸為底,線段為側壁,構成一個“容器”。求這個容器所能容納的最大水量。

用數學語言表達就是:

給定數組:

我們要找到一對下標?,使得:

1.2 物理直覺與幾何建模

這道題的本質是一道幾何問題。我們可以把每個數看作是平面直角坐標系中的一根垂直線段,其底部在?x?軸上。兩個線段與 x 軸圍成一個矩形槽,槽的高度取決于較短的那根線段,槽的寬度是兩個線段之間的距離。

我們要做的,就是找到這樣一對線段,使得這個“槽”的面積最大。

這個問題在現實世界中也有對應,比如修建兩個擋水壩,在中間蓄水;又比如數據中心的冷卻系統設計中,如何在有限結構中最大限度引導冷卻液的流動。

二、暴力算法的嘗試:最直接但最慢的方案

2.1 暴力破解:窮盡所有可能

最直觀的思路是:我們可以枚舉所有可能的左右邊界組合,然后計算它們圍成的面積,最后取最大值。

偽代碼如下:

max_area =?0
for?i?in?range(n):for?j?in?range(i +?1, n):area = min(height[i], height[j]) * (j - i)max_area = max(max_area, area)

2.2 時間復雜度分析

這個算法的時間復雜度是?,因為我們對每一對可能的?(i, j)?都進行了面積計算。在最壞情況下,當?n = 10^5?時,計算量為?,這是不可接受的。

2.3 空間復雜度

空間復雜度仍為?,因為我們沒有使用額外空間存儲結構。

三、數學建模與優化策略

3.1 關鍵思想:從局部最優走向全局最優

我們可以采用“雙指針”策略:設置兩個指針,一個從左邊開始(left),一個從右邊開始(right)。每次計算當前區間組成的容器面積,然后將較短的那一邊向中間移動。為什么?因為移動較短邊可能找出更高的線段,從而有機會獲得更大的面積。

def?maxArea(height):left, right =?0, len(height) -?1max_area =?0while?left < right:width = right - lefth = min(height[left], height[right])max_area = max(max_area, width * h)if?height[left] < height[right]:left +=?1else:right -=?1return?max_area

3.2 算法的正確性證明

核心邏輯:我們始終從當前最大可能寬度開始,然后不斷減小寬度的同時,嘗試找到更高的線段提升高度,以挽救面積的損失。

證明思路

  • 假設當前區間是?i?到?j,高度分別是?h_i?和?h_j,寬度是?j - i

  • 如果?h_i < h_j,我們知道以?i?為左邊界,任何再往右的線段?h_kk > i)和?h_j?組成的容器,其寬度必然小于當前寬度。

  • 若我們不移動?i,只移動?j,則高度肯定不會高于當前?h_i,面積只會變小。

  • 因此我們必須移動較短的一邊,才有可能找到更高的線段來補償寬度的損失。

3.3 時間與空間復雜度

  • 時間復雜度:,因為每個元素最多被訪問一次。

  • 空間復雜度:。

四、深度剖析:為什么雙指針能帶來線性優化?

4.1 雙指針的經典應用場景

“雙指針”是一種極為重要的算法技巧,常用于:

  • 對撞指針(如本題)

  • 快慢指針(如鏈表中找環)

  • 滑動窗口(如最大子數組和/最小覆蓋子串)

其核心思想是:在有序或可比較結構中,通過兩個游走指針節省無謂的枚舉,達到線性優化的目的。

4.2 為什么移動較短邊更優?

一個深刻的數學事實是:面積的計算是由最短邊決定的。如果我們保持較短邊不動而移動較長邊,我們只是在犧牲寬度的同時保持高度不變,甚至更低。因此,為了可能的提升,總是移動較短邊是最優策略。

這是一種貪婪策略:我們每一步都想博取最大提升空間。

4.3 與其他優化策略的對比

  • 動態規劃不適用:問題不像“最優子結構”那樣可以拆解。

  • 分治法也不適合:左右分治無法有效組合兩個子區間的面積。

  • 單調棧雖強大,但本題無需維持單調結構。

這正是雙指針大顯身手的領域。

五、極限測試與邊界思維:算法在實際中的魯棒性

5.1 極小輸入

  • [1, 1]?→ 結果為?1,邊界處理正確。

5.2 極大輸入

  • 當數組長度為??且元素最大為??時,算法仍能線性時間處理,優越性顯著。

5.3 高度全相等

  • [5, 5, 5, 5, 5]?→ 選擇最遠的兩個線段,寬度最大,面積為?5 * (n-1)

六、從“裝水”到“最優選擇”的人類思維模型

6.1 貪婪問題

這道題的本質是一個貪婪問題:每一步都做出當前最優決策,以期達到整體最優。它對應著人類在資源有限的世界中,如何在本地信息指導下做出選擇。

6.2 從計算到決策:數學模型的抽象價值

“裝水”問題其實是一種資源分配模型:有限的空間,尋找最大利用。這種模型在經濟學、運籌學、數據科學中普遍出現。

6.3 短板效應與邊界約束

在整個問題中,始終是“較短的那根線”決定著容量。這是著名的“木桶原理”的抽象體現:系統的容量由最短板決定。

七、擴展與變種:問題的泛化與挑戰

7.1 三維版本:最大水池問題

給定一個二維矩陣,如何找出圍成水池的最大體積?這引出了“接雨水 II”問題。

7.2 動態數據流中的最大容器

如果線段是動態輸入的呢?我們能否在滑動窗口中維護最大面積?這里需要引入數據結構,如單調隊列。

7.3 多個容器的最大總水量

如果可以選擇多個不重疊的容器,如何實現總水量最大?問題轉化為區間選擇與動態規劃的結合。

八、結語

我們不只是為了寫一個能通過測試的程序,而是為了培養那種從混沌中提煉規則、從有限中尋找最優的能力。算法,正是這個時代最重要的思維工具之一。

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

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

相關文章

無人機避障——深藍學院浙大Ego-Planner規劃部分

ESDF-free&#xff1a; 被這種類型的障礙物死死卡住的情況&#xff1a; 在一定范圍內建立ESDF&#xff1a; Ego-Planner框架&#xff1a; 找到{p,v} pair&#xff1a; 【注意】&#xff1a;首先根據在障礙物內航跡上的點Q&#xff0c;以及與它相鄰但不在障礙物內的兩個點&#…

零基礎設計模式——大綱匯總

零基礎學設計模式 - 大綱 前言 本教程旨在幫助零基礎的同學快速入門設計模式&#xff0c;理解其核心思想和應用場景。我們將通過清晰的講解和簡單的示例&#xff0c;逐步引導你掌握常用的設計模式。 第一部分&#xff1a;設計模式入門 什么是設計模式&#xff1f; 設計模式…

leetcode 92. Reverse Linked List II

題目描述 92. Reverse Linked List II 是第206題的進階版206. Reverse Linked List 思路很簡單&#xff0c;但一次性通過還是有點難度的。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(n…

CUDA的設備,流處理器(Streams),核,線程塊(threadblock),線程,網格(?gridDim),塊(block)和多gpu設備同步數據概念

CUDA的設備,流處理器&#xff0c;核&#xff0c;線程塊&#xff08;threadblock&#xff09;&#xff0c;線程&#xff0c;網格&#xff08;?gridDim&#xff09;&#xff0c;塊&#xff08;block&#xff09;和多gpu設備同步數據概念 CUDA的設備,流處理器&#xff0c;核&…

spring5-配外部文件-spEL-工廠bean-FactoryBean-注解配bean

spring配外部文件 我們先在Spring里配置一個數據源 1.導c3p0包,這里我們先學一下hibernate持久化框架&#xff0c;以后用mybites. <dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId><version>5.2.…

Feature Toggle 不再亂:如何設計一個干凈、安全、可控的特性開關系統?

網羅開發 &#xff08;小紅書、快手、視頻號同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企業從事人工智能項目研發管理工作&#xff0c;平時熱衷于分享各種編程領域的軟硬技能知識以及前沿技術&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…

技術分享:大數據挖掘平臺架構設計與行業應用實踐

在數字化轉型浪潮下&#xff0c;企業數據規模呈指數級增長。如何構建高效的數據挖掘體系&#xff0c;實現數據價值變現&#xff0c;成為技術團隊面臨的重要課題。本文將深入探討大數據挖掘平臺的核心架構、關鍵技術及行業應用實踐。 一、平臺架構設計 1. 數據采集層 支持多源異…

計算機視覺與深度學習 | EMD-KPCA-LSTM、EMD-LSTM、LSTM回歸預測對比,多輸入單輸出(Matlab完整程序和數據)

以下是針對EMD-KPCA-LSTM、EMD-LSTM和LSTM回歸預測對比的完整可運行MATLAB實現。包含數據生成、特征處理、模型構建和性能評估全流程,并提供關鍵代碼注釋和注意事項。 完整代碼實現(含數據生成) %% 清理環境 clear; clc; close all; warning off;%% 生成模擬數據(正弦波+噪…

Axure應用交互設計:動態面板嵌套實現超強體驗感菜單表頭

親愛的小伙伴,在您瀏覽之前,煩請關注一下,在此深表感謝!如有幫助請訂閱專欄! Axure產品經理精品視頻課已登錄CSDN可點擊學習https://edu.csdn.net/course/detail/40420 課程主題:動態面板嵌套 主要內容:利用動態面板多層嵌套實現菜單表頭 應用場景:廣泛應用于表單表…

HarmonyOS 鴻蒙應用開發基礎:父組件和子組件的通信方法總結

在鴻蒙開發中&#xff0c;ArkUI聲明式UI框架提供了一種現代化、直觀的方式來構建用戶界面。然而&#xff0c;由于其聲明式的特性&#xff0c;父組件與子組件之間的通信方式與傳統的命令式框架有所不同。本文旨在詳細探討在ArkUI框架中&#xff0c;父組件和子組件通信的方法總結…

深度學習模塊縫合拼接方法套路+即插即用模塊分享

前言 在深度學習中&#xff0c;模型的設計往往不是從頭開始&#xff0c;而是通過組合不同的模塊來構建。這種“模塊縫合”技術&#xff0c;就像搭積木一樣&#xff0c;把不同的功能模塊拼在一起&#xff0c;形成一個強大的模型。今天&#xff0c;我們就來聊聊四種常見的模塊縫…

計算機網絡(2)——應用層

1.應用層概述 應用層(Application Layer)屬于計算機網絡體系結構中的最頂層&#xff0c;直接面向用戶&#xff0c;提供各種網絡服務和應用程序的接口 本文主要的學習內容如下&#xff1a; (1)網絡應用進程通信方式 客戶端-服務器方式點對點方式混合方式 (2)網絡應用的需求與傳輸…

Android 繪制折線圖

用了一段時間的 Jetpack Compose ,感覺寫 UI 的效率確實會提升不少 。 配合 AI 編程繪制了一個折線圖。供大家學習參考! @Composable fun TemperatureChart() {val timeLabels = listOf("7:00", "8:00", "9:00", "10:00", "11:…

JavaScript- 1.3 DOM對頁面內容進行操作

本系列可作為前端學習系列的筆記&#xff0c;代碼的運行環境是在HBuilder中&#xff0c;小編會將代碼復制下來&#xff0c;大家復制下來就可以練習了&#xff0c;方便大家學習。 HTML和CSS系列文章 已經收錄在前端專欄&#xff0c;有需要的寶寶們可以點擊前端專欄查看&#xff…

CSS-5.1 Transition 過渡

本系列可作為前端學習系列的筆記&#xff0c;代碼的運行環境是在HBuilder中&#xff0c;小編會將代碼復制下來&#xff0c;大家復制下來就可以練習了&#xff0c;方便大家學習。 HTML系列文章 已經收錄在前端專欄&#xff0c;有需要的寶寶們可以點擊前端專欄查看&#xff01; 點…

使用Google 最新發布的veo-3 視頻生成和數字人技術制作介紹核聚變技術的短視頻:《逐夢星海:中國聚變照亮未來》

文章大綱 結合谷歌最新模型說明示例分鏡提示詞(基于 Gemini 2.5)最終視頻生成(基于 Veo3)解說詞文稿應用場景參考文獻先來看看效果: 視頻中混入了一些字幕,看來Google的技術還有待提高哈,里面有的托卡馬克好像挺像那么回事!厲害 逐夢星海:中國聚變照亮未來 #mermaid-sv…

服務器數據恢復—Linux系統服務器崩潰且重裝系統的數據恢復案例

服務器數據恢復環境&#xff1a; linux操作系統服務器中有一組由4塊SAS接口硬盤組建的raid5陣列。 服務器故障&#xff1a; 服務器工作過程中突然崩潰。管理員將服務器操作系統進行了重裝。 用戶方需要恢復服務器中的數據庫、辦公文檔、代碼文件等。 服務器數據恢復過程&#…

結構型:門面模式(外觀模式)

目錄 1、核心思想 2、實現方式 2.1 模式結構 2.2 實現案例 3、優缺點分析 4、適用場景 1、核心思想 目的&#xff1a;通過高層接口&#xff08;門面類&#xff09;封裝多個子系統的復雜交互&#xff0c;客戶端只需與門面交互&#xff0c;簡化入口&#xff1b;同時隔離客…

MidJourney生成王昭君全身像提示詞

漢服王昭君全身像&#xff0c;中國水墨融合工筆畫風格&#xff0c;低飽和度暖色調&#xff0c;絹本設質感&#xff1a; 服飾細節&#xff1a;身著朱紅色曲裾深衣&#xff0c;衣擺拖地三層&#xff0c;金線刺繡鳳凰祥云暗紋&#xff0c;寬袖綴珍珠滾邊&#xff0c;腰間白玉組佩…

GitHub 趨勢日報 (2025年05月21日)

本日報由 TrendForge 系統生成 https://trendforge.devlive.org/ &#x1f310; 本日報中的項目描述已自動翻譯為中文 &#x1f4c8; 今日整體趨勢 Top 10 排名項目名稱項目描述今日獲星總星數語言1microsoft/WSLLinux的Windows子系統? 1731? 25184C2virattt/ai-hedge-fundA…