2696。刪除子字串後的最小字串長度
難度:簡單
主題:字串、堆疊、模擬
給你一個只由大寫英文字母組成的字串s。
您可以對此字串套用一些操作,其中在一次操作中,您可以從 s 中刪除子字串「AB」或「CD」之一的任何出現。
傳回您可以得到的最小結果字串的可能長度。
注意刪除子字串後字串連接,可能會產生新的「AB」或「CD」子字串。
範例1:
- 輸入: s = "ABFCACDB"
- 輸出: 2
-
說明:我們可以進行以下操作:
- 刪除子字串“ABFCACDB”,因此 s =“FCACDB”。
- 刪除子字串“FCACDB”,因此 s =“FCAB”。
- 刪除子字串“FCAB”,因此 s =“FC”。
- 因此字串的長度為 2。
- 可以證明,這是我們可以得到的最小長度。
範例2:
- 輸入: s = "ACBBD"
- 輸出: 5
- 解釋:我們無法對字串進行任何操作,因此長度保持不變。
約束:
- 1
- s 僅由大寫英文字母組成。
提示:
- 我們可以用暴力破解這個問題嗎?
- 反覆遍歷字串尋找並刪除子字串“AB”和“CD”,直到不再出現。
解:
我們將使用堆疊來處理子字串「AB」和「CD」的刪除。堆疊方法確保我們在遍歷字串期間有效地刪除這些子字串。
方法:
-
使用堆疊:
- 逐字遍歷字串。
- 將每個字元壓入堆疊。
- 如果堆疊頂部的兩個字元形成子字串“AB”或“CD”,則將這兩個字元從堆疊中彈出(刪除它們)。
- 對輸入字串中的所有字元繼續此過程。
-
最終字串:
- 遍歷結束時,堆疊將包含縮減後的字串。
- 最小可能長度將是堆疊的大小。
讓我們用 PHP 實作這個解:2696。刪除子字串後的最小字串長度
<?php <br> /**
- @param String $s
- @return Integer /
- go to ./solution.php */
// Example usage:
echo minLengthAfterRemovals("ABFCACDB"); // Output: 2
echo "\n";
echo minLengthAfterRemovals("ACBBD"); // Output: 5
?>
說明:
- 我們初始化一個空堆疊($stack)。
- 循環遍歷字串 s 的每個字元。
- 檢查堆疊頂部的字元:
- 如果頂部字元和當前字元形成子字串“AB”或“CD”,我們使用 array_pop 刪除頂部字元。
- 否則,將目前字元壓入堆疊。
- 堆疊將保存所有可能的刪除後剩餘的字元。
- 最後,count($stack) 給出結果字串的長度。
複雜:
- 時間複雜度:O(n),其中n是字串的長度。每個字元最多被處理兩次(一次推送,一次彈出)。
- 空間複雜度:堆疊的 O(n),在最壞的情況下無法進行刪除。
此解決方案透過刪除所有可能出現的「AB」和「CD」直到找不到更多的字串,有效地最小化字串。
聯絡連結
如果您發現本系列有幫助,請考慮在 GitHub 上給 存儲庫 一個星號或在您最喜歡的社交網絡上分享該帖子? 。您的支持對我來說意義重大!
如果您想要更多類似的有用內容,請隨時關注我:
- 領英
- GitHub
以上是刪除子字串後的最小字串長度的詳細內容。更多資訊請關注PHP中文網其他相關文章!

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增強codemodocultion,可驗證性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

選擇DependencyInjection(DI)用於大型應用,ServiceLocator適合小型項目或原型。 1)DI通過構造函數注入依賴,提高代碼的測試性和模塊化。 2)ServiceLocator通過中心註冊獲取服務,方便但可能導致代碼耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)啟用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替換loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化進行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3漢化版
中文版,非常好用