C++使用棧實現(xiàn)括號匹配的代碼詳解
引言
在編程中,括號匹配是一個常見問題,尤其是在處理數(shù)學(xué)表達式、編譯器解析等任務(wù)時。棧(Stack)是一種非常適合處理此類問題的數(shù)據(jù)結(jié)構(gòu),因為棧具有“后進先出(LIFO)”的特性,能夠精確地管理括號的匹配問題。
本文將通過 C++ 代碼,詳細(xì)講解如何使用棧來實現(xiàn)括號匹配,它的原理是什么、邏輯結(jié)構(gòu)實現(xiàn)是怎樣的,并通過符號表示棧的狀態(tài),幫助你理解棧的應(yīng)用。
問題描述
給定一個字符串,包含三種類型的括號:(
, )
, [
, ]
。我們需要判斷字符串中的括號是否正確配對。如果每個左括號都有對應(yīng)的右括號,并且括號的配對順序是正確的,則返回 true
;否則返回 false
。
例如:
- 輸入:
"[()]"
,輸出:true
- 輸入:
"[(])"
,輸出:false
代碼講解
#include "bits/stdc++.h" using namespace std; bool search(string str) { stack<char> s; // 創(chuàng)建一個棧來存儲左括號 for(char c : str) { // 遍歷字符串中的每個字符 if(c == '[' || c == '(') { // 如果是左括號,壓棧 s.push(c); } else if(s.empty()) { // 如果是右括號,但棧為空,說明沒有匹配的左括號 return false; } else if(c == ']' && s.top() == '[') { // 如果是右括號,且棧頂是左括號 s.pop(); // 匹配成功,彈出棧頂元素 } else if(c == ')' && s.top() == '(') { // 如果是右括號,且棧頂是左括號 s.pop(); // 匹配成功,彈出棧頂元素 } else { return false; // 如果右括號與棧頂不匹配,返回 false } } return s.empty(); // 如果棧為空,則所有括號匹配成功,返回 true;否則返回 false } int main() { cout << search("[])" ) << endl; // 測試輸入 return 0; }
代碼解析
棧初始化
在search
函數(shù)開始時,我們創(chuàng)建了一個字符類型的棧s
,用于存儲遇到的左括號'('
和'['
。遍歷字符串
我們通過for (char c : str)
遍歷字符串中的每個字符。左括號處理
如果當(dāng)前字符是左括號'('
或'['
,我們就將它壓入棧中。右括號處理
如果當(dāng)前字符是右括號')'
或']'
,我們首先檢查棧是否為空:- 如果棧為空,說明沒有匹配的左括號,因此返回
false
。 - 否則,我們檢查棧頂元素是否是對應(yīng)的左括號。如果匹配,則彈出棧頂元素,表示這對括號已經(jīng)匹配成功。
- 如果不匹配,則返回
false
,說明括號順序有誤。
- 如果棧為空,說明沒有匹配的左括號,因此返回
檢查棧是否為空
遍歷結(jié)束后,如果棧為空,說明所有的括號都匹配成功了。否則,返回false
,表示還有未匹配的左括號。
棧的狀態(tài)表示
為了便于理解棧的變化,我們使用符號表示當(dāng)前棧的狀態(tài)。棧的元素從棧底到棧頂按順序排列。
示例 1:輸入 "[()]"
- 初始狀態(tài):棧為空:
[]
- 處理字符
'['
,將其壓棧:['[']
- 處理字符
'('
,將其壓棧:['[', '(']
- 處理字符
')'
,棧頂是'('
,匹配成功,彈出棧頂:['[']
- 處理字符
']'
,棧頂是'['
,匹配成功,彈出棧頂:[]
- 最終棧為空,所有括號匹配成功,返回
true
。
示例 2:輸入 "[(])"
- 初始狀態(tài):棧為空:
[]
- 處理字符
'['
,將其壓棧:['[']
- 處理字符
'('
,將其壓棧:['[', '(']
- 處理字符
')'
,棧頂是'('
,匹配成功,彈出棧頂:['[']
- 處理字符
']'
,棧頂是'['
,匹配成功,彈出棧頂:[]
- 最終棧為空,所有括號匹配成功,返回
true
,但實際上,括號順序錯誤,程序應(yīng)該返回false
。
測試
cout << search("[])" ) << endl; // 測試輸入
對于輸入 "[])"
,程序的執(zhí)行過程如下:
- 初始狀態(tài):棧為空:
[]
- 處理字符
'['
,將其壓棧:['[']
- 處理字符
']'
,棧頂是'['
,匹配成功,彈出棧頂:[]
- 處理字符
')'
,棧為空,表示沒有匹配的左括號,返回false
。
總結(jié)
通過這段代碼和符號化的棧狀態(tài)表示,可以清晰的了解棧在括號匹配中的應(yīng)用。棧的“后進先出”特性使得它非常適合解決括號配對問題。在實際編程中,棧還可以用于其他多種場景,比如函數(shù)調(diào)用管理、深度優(yōu)先搜索等。
以上就是C++使用棧實現(xiàn)括號匹配的代碼詳解的詳細(xì)內(nèi)容,更多關(guān)于C++棧實現(xiàn)括號匹配的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
c++ 如何在libuv中實現(xiàn)tcp服務(wù)器
這篇文章主要介紹了c++ 如何在libuv中實現(xiàn)tcp服務(wù)器,幫助大家更好的理解和使用libuv,感興趣的朋友可以了解下2021-02-02用C語言求冪函數(shù)和指數(shù)函數(shù)的方法
這篇文章主要介紹了用C語言求冪函數(shù)和指數(shù)函數(shù)的方法,即pow()函數(shù)和sqrt()函數(shù)的使用,需要的朋友可以參考下2015-08-08C++中constexpr與函數(shù)參數(shù)轉(zhuǎn)發(fā)的操作方法
constexpr是c++11引入的關(guān)鍵字,c++11的constexpr的函數(shù)中只是支持單句代碼,c++14限制放寬,可以在里邊寫循環(huán)及邏輯判斷等語句,本文探討關(guān)于constexpr的函數(shù)中參數(shù)的現(xiàn)象,以及如果參數(shù)是constexpr如何做轉(zhuǎn)發(fā),感興趣的朋友一起看看吧2024-02-02