本文說明瞭如何使用Java查找最長平衡括號前綴的長度。首先,我們將使用幾個示例理解問題,然後學習兩種不同的方法來尋找問題。
問題解釋在這裡,我們給出一個包含括號的字符串,我們需要從字符串中找到平衡的括號集的長度。換句話說,如果有所有開口括號
“(”(“”),那麼我們將其稱為平衡。 從字符串的開頭,前綴定義平衡集。例如,對於括號集'(())()',僅'(())'。 >輸入和輸出方案
為了更好地理解,讓我們看一些輸入和輸出方案。
如果輸入字符串為
“(()”,平衡括號前綴為
()- ,則長度為2。
- 如果輸入字符串為”(((())))(((“),平衡括號前綴為((()(()(()(()) )))>所以長度為8。 >
- 如果輸入字符串為“(()()())()()”,平衡的括號前綴為(()()()()),則長度是6。
- 最長平衡括號前綴的長度可以找到如下: 使用堆棧數據結構 計數打開和關閉括號
使用堆棧數據結構
- >可以使用堆棧。如果從堆棧中找到開口括號' (
- ',請將其推到堆棧上。如果找到閉合括號,請彈出堆棧,並將計數器變量增加2(平衡均值的長度您得到的是2 。)繼續執行此操作,並在變為空堆棧時返回計數器變量 >算法
算法如下:
如果字符為
(>,將其推到堆棧上。>
如果
字符為)
,則會彈出堆棧。<code><p><b>ステップ1:</b>スタックとカウンタを初期化します。</p> <p><b>ステップ2:</b>文字列の各文字を反復処理します。</p></code>
- >將計數器增加2。
- 檢查堆棧是否為空。 如果是空的,則結束循環。
- > 步驟3:
-
>示例
<code><p><b>ステップ1:</b>スタックとカウンタを初期化します。</p> <p><b>ステップ2:</b>文字列の各文字を反復処理します。</p></code>
輸出
輸入字符串是:((())((() 最長平衡括號前綴的長度為:6>
計數打開和關閉括號此方法使用兩個變量:計數和長度。如果字符為“
”(>”,則從字符串中獲得1;如果字符計數為1;如果字符為“)”,則減少數量為1,而增量長度則增加2。檢查計數是否為0,如果是0,則退出循環並返回長度。 >示例
import java.util.Stack; public class Example { public static int longestBalancedPrefix(String s) { Stack<Character> stack = new Stack<>(); int count = 0; for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if (c == '(') { stack.push(c); } else if (c == ')') { if (!stack.isEmpty()) { stack.pop(); count += 2; } } if (stack.isEmpty()) { break; } } return count; } public static void main(String[] args) { String s = "((())((("; int length = longestBalancedPrefix(s); System.out.println("入力文字列は:" + s); System.out.println("最長のバランスの取れた括弧のプレフィックスの長さは:" + length); } }
輸出輸入字符串為((()()())((()))) 最長平衡的括號前綴長度為8
以上是使用Java的最長平衡括號前綴的長度的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在使用IntelliJIDEAUltimate版本啟動Spring...

在使用MyBatis-Plus或其他ORM框架進行數據庫操作時,經常需要根據實體類的屬性名構造查詢條件。如果每次都手動...

Redis緩存方案如何實現產品排行榜列表的需求?在開發過程中,我們常常需要處理排行榜的需求,例如展示一個�...

將姓名轉換為數字以實現排序的解決方案在許多應用場景中,用戶可能需要在群組中進行排序,尤其是在一個用...

電商平台SKU和SPU表設計詳解本文將探討電商平台中SKU和SPU的數據庫設計問題,特別是如何處理用戶自定義銷售屬...

在Idea中如何設置SpringBoot項目默認運行配置列表在使用IntelliJ...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SublimeText3 Linux新版
SublimeText3 Linux最新版

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

禪工作室 13.0.1
強大的PHP整合開發環境

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