legongju.com
我们一直在努力
2025-01-12 08:01 | 星期天

如何使用c++ stack类实现括号匹配

使用C++的stack类可以实现括号匹配。具体步骤如下:

  1. 定义一个stack对象,用于存储左括号。

  2. 遍历输入的字符串,当遇到左括号时,将其压入stack中。

  3. 当遇到右括号时,检查stack是否为空,如果为空,则说明没有匹配的左括号,返回false;否则,将栈顶的左括号弹出,检查是否与当前的右括号匹配,如果匹配,则继续遍历,否则返回false。

  4. 遍历结束后,检查stack是否为空,如果为空,则说明所有的括号都匹配成功,返回true;否则,返回false。

下面是具体的C++代码实现:

#include 
#include 
#include 
using namespace std;

bool isMatch(string s) {
    stack st;
    for (int i = 0; i < s.size(); i++) {
        if (s[i] == '(') {
            st.push(')');
        } else if (s[i] == '[') {
            st.push(']');
        } else if (s[i] == '{') {
            st.push('}');
        } else if (st.empty() || st.top() != s[i]) {
            return false;
        } else {
            st.pop();
        }
    }
    return st.empty();
}

int main() {
    string s = "()[]{}";
    cout << (isMatch(s) ? "匹配成功" : "匹配失败") << endl;
    return 0;
}

输出结果为:

匹配成功

未经允许不得转载 » 本文链接:https://www.legongju.com/article/80838.html

相关推荐

  • c#怎么引用类

    c#怎么引用类

    在C#中,要引用一个类,首先需要确保该类在当前项目或引用的程序集中。然后,可以使用using关键字将类所在的命名空间导入到当前文件中。接下来,就可以在代码中直...

  • c++爱心源代码怎么写

    c++爱心源代码怎么写

    在C++中,你可以使用ASCII字符来绘制一个简单的爱心形状。这里是一个示例代码:
    #include int main() { std::cout

  • c++ string的常用方法及其功能是什么

    c++ string的常用方法及其功能是什么

    C++中的string类包含了许多常用的方法,这些方法可以帮助我们完成各种字符串操作。以下是一些常用的string方法及其功能: length() 或 size(): 返回字符串的长度...

  • c++怎么读取一行字符串

    c++怎么读取一行字符串

    在C++中,你可以使用std::getline()函数从输入流(如std::cin)读取一行字符串
    #include
    #include int main() { std::string line; // 提示用户输入一...

  • c++ stack类能否获取栈顶元素

    c++ stack类能否获取栈顶元素

    是的,C++ STL(标准模板库)中的stack类提供了获取栈顶元素的方法。可以使用top()函数来获取栈顶元素,该函数返回栈顶元素的引用。例如:
    #include using ...

  • c++ stack类怎样检查是否为空

    c++ stack类怎样检查是否为空

    在 C++ 标准库中,stack 类没有直接提供一个成员函数来检查栈是否为空
    #include #include int main() { std::stack myStack; if (myStack.empty()) { std::...

  • 如何使用c++ stack类进行递归

    如何使用c++ stack类进行递归

    C++的stack类并不支持递归,因为它的主要作用是后进先出(LIFO)的数据结构,用于存储一系列的元素,并只能在其一端(称为栈顶)进行插入和删除操作。
    如果...

  • 如何在ubuntu上编译c++嵌入式程序

    如何在ubuntu上编译c++嵌入式程序

    在Ubuntu上编译C++嵌入式程序,你可以遵循以下步骤: 安装必要的开发工具和库: sudo apt update:更新你的系统包列表。
    sudo apt install build-essential...