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