IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 栈的应用:字符串的括号匹配问题(C语言) -> 正文阅读

[C++知识库]栈的应用:字符串的括号匹配问题(C语言)

问题描述

  • 输入一字符串,检查字符串中 { }、[ ]、( ) 三种括号是否成对出现。不同括号间不能交叉出现且左右括号顺序不能颠倒,如 ) (、{ ( } )等。
  • 匹配示例:{ ( ) } ,{ [ ( ) ] }等

解决方法

  • 利用栈的特性,发现左括号就入栈,然后检索到右括号与栈顶的左括号比对,如果为同一种括号则栈顶括号出栈;如果不是同一种括号(交叉)或者栈为空(只有右括号)则匹配失败。
  • 最后若栈空则说明括号匹配成功
    在这里插入图片描述

代码

#include <stdio.h>
#include <string.h>

/******************用数组实现栈的函数*******************/
struct stack  //存放栈的信息
{
    int top;
    char *bottom;
    int size;
};

int IsEmpty(struct stack *s) //判空
{
    if (s->top == -1)
    {

        return 0;
    }
    else
    {
        return 1;
    }
}
int push(struct stack *s, char x)  //入栈
{
    char *p = s->bottom;
    p[++(s->top)] = x;
}

int pop(struct stack *s)  //出栈
{
    int ret = IsEmpty(s);
    if (ret == 0)
    {
        printf("此栈已空\n");
        return 0;
    }

    s->top--;
}
/*********************************************************/


char rToL(char c)   //右括号转左括号
{
    switch (c)
    {
	    case '}':
	        return '{';
	    case ']':
	        return '[';
	    case ')':
	        return '(';
    }
}

int main()
{
    int i = 0;
    int MAX = 1024;  //字符数组的最大值
    char str[MAX];   //存放字符串的空间

    fgets(str, MAX, stdin); //从终端读取一个字符串
    int size = strlen(str); //字符串的大小
    
    char stack[size];  //栈的空间与字符串大小想等
    struct stack s = {-1, stack, size}; //定义栈的信息
    
    for (i = 0; i < size; i++) //遍历字符串
    {

        if (str[i] == '{' || str[i] == '[' || str[i] == '(') //有左括号就入栈
        {
            push(&s, str[i]);
        }
        if (str[i] == '}' || str[i] == ']' || str[i] == ')') 
        {
            str[i] = rToL(str[i]);  //把右括号转成左括号
            if (stack[s.top] == str[i])  //与栈顶括号比较
            {
                pop(&s);   //相同则出栈
            }
            else
            {
                printf("括号不匹配!\n");
                return 0;
            }
        }
    }

    int ret = IsEmpty(&s); //判空
    if (ret == 0)
    {
        printf("括号匹配^v^!\n");
    }
    else
    {
        printf("括号不匹配!\n");
    }
    return 0;
}

终端显示

  • 第一次在终端输入字符串p[++(s->top)] = x ;
p[++(s->top)] = x;
括号匹配^v^!
  • 第二次在终端输入字符串if (str[i] == ‘{’ || str[i] == ‘[’ || str[i] == ‘(’ ) :
if (str[i] == '{' || str[i] == '[' || str[i] == '(')
括号不匹配!

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-17 15:11:24  更:2021-08-17 15:15:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 7:33:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码