欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++使用棧實(shí)現(xiàn)括號(hào)匹配的代碼詳解

 更新時(shí)間:2025年02月23日 15:17:38   作者:XuanRanDev  
在編程中,括號(hào)匹配是一個(gè)常見(jiàn)問(wèn)題,尤其是在處理數(shù)學(xué)表達(dá)式、編譯器解析等任務(wù)時(shí),棧是一種非常適合處理此類問(wèn)題的數(shù)據(jù)結(jié)構(gòu),能夠精確地管理括號(hào)的匹配問(wèn)題,本文將通過(guò) C++ 代碼,詳細(xì)講解如何使用棧來(lái)實(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;
}

代碼解析

  1. 棧初始化
    search函數(shù)開(kāi)始時(shí),我們創(chuàng)建了一個(gè)字符類型的棧 s,用于存儲(chǔ)遇到的左括號(hào) '(' 和 '['。

  2. 遍歷字符串
    我們通過(guò) for (char c : str) 遍歷字符串中的每個(gè)字符。

  3. 左括號(hào)處理
    如果當(dāng)前字符是左括號(hào) '(' 或 '[',我們就將它壓入棧中。

  4. 右括號(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)順序有誤。
  5. 檢查棧是否為空
    遍歷結(jié)束后,如果棧為空,說(shuō)明所有的括號(hào)都匹配成功了。否則,返回 false,表示還有未匹配的左括號(hào)。

棧的狀態(tài)表示

為了便于理解棧的變化,我們使用符號(hào)表示當(dāng)前棧的狀態(tài)。棧的元素從棧底到棧頂按順序排列。

示例 1:輸入 "[()]"

  1. 初始狀態(tài):棧為空:[]
  2. 處理字符 '[',將其壓棧:['[']
  3. 處理字符 '(',將其壓棧:['[', '(']
  4. 處理字符 ')',棧頂是 '(',匹配成功,彈出棧頂:['[']
  5. 處理字符 ']',棧頂是 '[',匹配成功,彈出棧頂:[]
  6. 最終棧為空,所有括號(hào)匹配成功,返回 true

示例 2:輸入 "[(])"

  1. 初始狀態(tài):棧為空:[]
  2. 處理字符 '[',將其壓棧:['[']
  3. 處理字符 '(',將其壓棧:['[', '(']
  4. 處理字符 ')',棧頂是 '(',匹配成功,彈出棧頂:['[']
  5. 處理字符 ']',棧頂是 '[',匹配成功,彈出棧頂:[]
  6. 最終棧為空,所有括號(hào)匹配成功,返回 true,但實(shí)際上,括號(hào)順序錯(cuò)誤,程序應(yīng)該返回 false。

測(cè)試

cout << search("[])" ) << endl; // 測(cè)試輸入

對(duì)于輸入 "[])",程序的執(zhí)行過(guò)程如下:

  1. 初始狀態(tài):棧為空:[]
  2. 處理字符 '[',將其壓棧:['[']
  3. 處理字符 ']',棧頂是 '[',匹配成功,彈出棧頂:[]
  4. 處理字符 ')',棧為空,表示沒(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++中new和delete為什么要匹配使用嗎

    你知道C++中new和delete為什么要匹配使用嗎

    關(guān)于 new 和 delete 的使用相信大家并不陌生,可是為什么使用 new 的時(shí)候要用 delete,使用 new[] 的時(shí)候又要用 delete[]呢?本文就來(lái)和大家詳細(xì)說(shuō)說(shuō)
    2023-01-01
  • c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器

    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ù)的方法

    這篇文章主要介紹了用C語(yǔ)言求冪函數(shù)和指數(shù)函數(shù)的方法,即pow()函數(shù)和sqrt()函數(shù)的使用,需要的朋友可以參考下
    2015-08-08
  • C語(yǔ)言二叉排序樹(shù)的創(chuàng)建,插入和刪除

    C語(yǔ)言二叉排序樹(shù)的創(chuàng)建,插入和刪除

    本文主要介紹了Java實(shí)現(xiàn)二叉排序樹(shù)的查找、插入、刪除、遍歷等內(nèi)容。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2021-10-10
  • C++關(guān)鍵字const使用方法詳解

    C++關(guān)鍵字const使用方法詳解

    C語(yǔ)言中的const與C++有很大的不同,在C語(yǔ)言中用const修飾的變量仍是一個(gè)變量,表示這個(gè)變量是只讀的,不可顯示地更改,C++中的const關(guān)鍵字的用法非常靈活,而使用const將大大改善程序的健壯性,const關(guān)鍵字是一種修飾符
    2022-12-12
  • C++中實(shí)現(xiàn)OpenCV圖像分割與分水嶺算法

    C++中實(shí)現(xiàn)OpenCV圖像分割與分水嶺算法

    分水嶺算法是一種常用的圖像區(qū)域分割法,本文主要介紹了OpenCV圖像分割與分水嶺算法,使用C++實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-06-06
  • c++ 如何合并兩個(gè)有序鏈表

    c++ 如何合并兩個(gè)有序鏈表

    這篇文章主要介紹了c++ 如何合并兩個(gè)有序鏈表,幫助大家更好的理解和學(xué)習(xí)C++,感興趣的朋友可以了解下
    2020-08-08
  • C++中constexpr與函數(shù)參數(shù)轉(zhuǎn)發(fā)的操作方法

    C++中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
  • 12個(gè)C語(yǔ)言必背實(shí)例分享

    12個(gè)C語(yǔ)言必背實(shí)例分享

    這篇文章主要和大家介紹12個(gè)C語(yǔ)言中必背的實(shí)例,文中的示例代碼講解詳細(xì),對(duì)我們了解和掌握C語(yǔ)言有一定的幫助,感興趣的小伙伴快跟隨小編一起了解一下
    2022-11-11
  • C++實(shí)現(xiàn)通訊錄小功能

    C++實(shí)現(xiàn)通訊錄小功能

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)通訊錄小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評(píng)論