栈以及括号匹配

article/2025/10/25 19:08:01

栈以及括号匹配

    • 一、栈:
    • 二、定义:
    • 三、入栈:
    • 四、出栈:
    • 五、测试代码:
    • 六、括号匹配
    • 七、测试代码
    • 八、总代码
    • 九、测试结果

一、栈:

栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

二、定义:

代码演示:

typedef struct CharStack {int top;int data[STACK_MAX_SIZE];
} *CharStackPtr; 

三、入栈:

请添加图片描述
代码演示:

void push(CharStackPtr paraStackPtr, int paraValue){if(paraStackPtr->top>=STACK_MAX_SIZE-1){printf("can't push , Stack is full.\n\r");return;}paraStackPtr->top++;paraStackPtr->data[paraStackPtr->top]=paraValue;
}

四、出栈:

请添加图片描述
代码演示:

char pop(CharStackPtr paraStackPtr){if(paraStackPtr->top<0){printf("can't pop , Stack is empty.\r\n");return '\0';}paraStackPtr->top--;return paraStackPtr->data[paraStackPtr->top+1];
}

五、测试代码:

void pushPopTest(){CharStackPtr tempStack = charStackInit();printf("After initialization, the stack is: ");outputStack(tempStack);for(char ch='a';ch<'m';ch++){push(tempStack,ch);outputStack(tempStack);}printf("---- pushPopTest ends. ----\r\n");
}

六、括号匹配

方法:
1、利用栈的特性,发现左括号就入栈,然后检索到右括号与栈顶的左括号比对,如果为同一种括号则栈顶括号出栈;如果不是同一种括号(交叉)或者栈为空(只有右括号)则匹配失败。
2、最后若栈空则说明括号匹配成功

请添加图片描述

代码演示:

bool bracketMatching(char* paraString, int paraLength){char tempChar, tempPopedChar;CharStackPtr tempStack=charStackInit();push (tempStack,'#');for(int i=0;i<paraLength;i++){tempChar=paraString[i];switch(tempChar){case'(':case'[':case'{':push(tempStack,tempChar);break;case')':tempPopedChar=pop(tempStack);if(tempPopedChar!='('){return false;}break;case']':tempPopedChar=pop(tempStack);if(tempPopedChar!='['){return false;}break;case'}':tempPopedChar=pop(tempStack);if(tempPopedChar!='{'){return false;}break;default:break;}
}
tempPopedChar=pop(tempStack);
if(tempPopedChar!='#'){return false;
}
return true;
}

七、测试代码

void bracketMatchingTest() {char* tempExpression = "[2 + (1 - 3)] * 4";bool tempMatch = bracketMatching(tempExpression, 17);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "( )  )";tempMatch = bracketMatching(tempExpression, 6);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "()()(())";tempMatch = bracketMatching(tempExpression, 8);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "({}[])";tempMatch = bracketMatching(tempExpression, 6);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = ")(";tempMatch = bracketMatching(tempExpression, 2);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);
}

八、总代码

#include<stdio.h>
#include<malloc.h>#define STACK_MAX_SIZE 10typedef struct CharStack {int top;int data[STACK_MAX_SIZE];
} *CharStackPtr; void outputStack(CharStackPtr paraStack){for(int i=0;i<=paraStack->top;i++){printf("%c",paraStack->data[i]);}printf("\r\n");
}CharStackPtr charStackInit() {CharStackPtr resultPtr = (CharStackPtr)malloc(sizeof(struct CharStack));resultPtr->top = -1;return resultPtr;
}void push(CharStackPtr paraStackPtr, int paraValue){if(paraStackPtr->top>=STACK_MAX_SIZE-1){printf("can't push , Stack is full.\n\r");return;}paraStackPtr->top++;paraStackPtr->data[paraStackPtr->top]=paraValue;
}char pop(CharStackPtr paraStackPtr){if(paraStackPtr->top<0){printf("can't pop , Stack is empty.\r\n");return '\0';}paraStackPtr->top--;return paraStackPtr->data[paraStackPtr->top+1];
}void pushPopTest(){CharStackPtr tempStack = charStackInit();printf("After initialization, the stack is: ");outputStack(tempStack);for(char ch='a';ch<'m';ch++){push(tempStack,ch);outputStack(tempStack);}printf("---- pushPopTest ends. ----\r\n");
}bool bracketMatching(char* paraString, int paraLength){char tempChar, tempPopedChar;CharStackPtr tempStack=charStackInit();push (tempStack,'#');for(int i=0;i<paraLength;i++){tempChar=paraString[i];switch(tempChar){case'(':case'[':case'{':push(tempStack,tempChar);break;case')':tempPopedChar=pop(tempStack);if(tempPopedChar!='('){return false;}break;case']':tempPopedChar=pop(tempStack);if(tempPopedChar!='['){return false;}break;case'}':tempPopedChar=pop(tempStack);if(tempPopedChar!='{'){return false;}break;default:break;}
}
tempPopedChar=pop(tempStack);
if(tempPopedChar!='#'){return false;
}
return true;
}void bracketMatchingTest() {char* tempExpression = "[2 + (1 - 3)] * 4";bool tempMatch = bracketMatching(tempExpression, 17);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "( )  )";tempMatch = bracketMatching(tempExpression, 6);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "()()(())";tempMatch = bracketMatching(tempExpression, 8);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = "({}[])";tempMatch = bracketMatching(tempExpression, 6);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);tempExpression = ")(";tempMatch = bracketMatching(tempExpression, 2);printf("Is the expression '%s' bracket matching? %d \r\n", tempExpression, tempMatch);
}
int main(){pushPopTest();bracketMatchingTest();
}

九、测试结果

After initialization, the stack is:
a
ab
abc
abcd
abcde
abcdef
abcdefg
abcdefgh
abcdefghi
abcdefghij
can't push , Stack is full.
abcdefghij
can't push , Stack is full.
abcdefghij
---- pushPopTest ends. ----
Is the expression '[2 + (1 - 3)] * 4' bracket matching? 1
Is the expression '( )  )' bracket matching? 0
Is the expression '()()(())' bracket matching? 1
Is the expression '({}[])' bracket matching? 1
Is the expression ')(' bracket matching? 0

http://chatgpt.dhexx.cn/article/6513vhIQ.shtml

相关文章

括号匹配问题详解

直接看题&#xff01;&#xff01; typedef char STDataType;typedef struct Stack {STDataType* a;int top; //栈顶的位置int capacity; //容量 }ST;void StackInit(ST* ps) {assert(ps);ps->a NULL;ps->top 0;ps->capacity 0;}void StackDestroy(ST* ps) {asse…

括号匹配

题目 给定一个只包括 (&#xff0c; )&#xff0c; {&#xff0c; }&#xff0c; [&#xff0c; ] 的字符串&#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 注意空字符串可被认为是有效…

数据结构——括号匹配问题

括号匹配 给定一个字符串&#xff0c;其中的字符只包含三种括号&#xff1a;花括号{ }、中括号[ ]、圆括号( )&#xff0c;即它仅由 “( ) [ ] { }” 这六个字符组成。设计算法&#xff0c;判断该字符串是否有效&#xff0c;即字符串中括号是否匹配。括号匹配要求括号必须以正…

C语言详解括号匹配问题(栈的应用 )

文章目录 问题概述算法思路不匹配的情况实现流程图C语言代码结果测试 问题概述 检测括号是否成对出现 最后出现的左括号最先匹配&#xff08;LIFO&#xff09;&#xff0c;和栈的后进先出异曲同工 每出现一个右括号&#xff0c;就抵消&#xff08;出栈操作&#xff09;掉一个…

括号匹配(c++)

20. 有效的括号&#xff08;力扣&#xff09; 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭…

【数据结构】【栈】括号匹配算法(可直接运行)

文章目录 1.算法问题2.算法思路3.算法实现4.完整代码5.运行结果 1.算法问题 假设表达式中允许包含三种括号&#xff1a;()、[]、{}&#xff0c;其嵌套的顺序任意&#xff0c;即([]{})或[()[]{}]等均为正确的格式&#xff0c;实现一个算法&#xff0c;完成对表达式中括号的检验…

CronTrigger(重要,非常强大)

&#xff0c;&#xff1a;表示或的关系 - &#xff1a;表示至的关系 * &#xff1a;表示每的关系 / &#xff1a;表示每的关系 # &#xff1a;表示第的关系 L &#xff1a;表示最后的关系 6 &#xff1a;表示星期五

CronTrigger定时任务

1、CronTrigger的作用&#xff1a;基于日历的作业调度器&#xff0c;而不是像SimpleTrigger那样精确指定间隔时间&#xff0c;比SimpleTrigger更常用。 2、Cron表达式 用于配置CronTrigger实例 是由7个子表达式组成的字符串&#xff0c;描述了时间表的详细信息 格式&#x…

Quartz(02) 两种Trigger(SimpleTrigger/CronTrigger)

上一章讲了Quartz 的几个核心概念(上一章节地址Quartz快速入门).接下来看看Quartz的两种Trigger. SimpleTrigger/CronTrigger. 简单的定时任务,可以采用SimpleTrigger,复杂的任务一般采用CronTrigger. 源码下载地址 1.SimpleTrigger   SimpleTrigger是Quartz中最简单Trig…

Quartz CronTrigger最完整触发时间配置说明

CronTrigger配置格式: 格式: [秒] [分] [小时] [日] [月] [周] [年] 序号说明 是否必填 允许填写的值允许的通配符 1 秒 是 0-59 , - * / 2 分 是 0-59 , - * / 3小时 是 0-23 , - * / 4 日 是 1-31 , - * ? / L W 5 月 是 1-12 or JAN-DEC , - * / 6 周 是 1-7 or SUN-…

Quartz-CronTrigger解读

文章目录 概述Cron表达式的组成cron表达式中的问号(?) 的含义1、当星期和日期都为*或数字时&#xff0c;报错2、当星期和日期都为?时&#xff0c;报错 时间格式特殊字符Cron 表达式样例CronTrigger 样例 1 – 时钟从 0 分钟开始&#xff0c;每 5 分钟执行一次CronTrigger 样例…

SimpleTrigger和CronTrigger配置说明和cornExpression表达式

CronTrigger基于日历和时间&#xff0c;SimpleTrigger基于时间。 每天8:32,12:32 执行一次&#xff0c;启动的时候执行一次&#xff1b; Java代码 <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/sprin…

【Java定时任务】浅谈CronTrigger的用法和在线Cron表达式生成网址

目录 0.CronTrigger的作用 1.Cron表达式 2.Cron表达式特殊字符意义对应表 0.CronTrigger的作用 CronTriggers往往比SimpleTrigger更有用&#xff0c;如果您需要基于日历的概念&#xff0c;而非SimpleTrigger完全指定的时间间隔&#xff0c;复发的发射工作的时间表。 CronTri…

CronTrigger cron表达式

Cron表达式 简单触发可以使用SimplTrigger实现类.功能类似timer 复杂触发可以使用CronTrigger实现类,内部利用cron表达式描述各种复杂的时间调度计划 举例 表示2022年9月3日凌晨4点的cron表达式 0 0 4 3 9 ? 2022 * 表示任何值,如果在分的字段上编写*,表示每分钟都会触发 …

crond和crontab详解

###一、crontab是什么&#xff1f;   1. 定时任务软件种类 at    适合仅执行一次就结束的调度命令&#xff0c;需要启动一个后端的atd服务。 crontab 需要启动一个服务crond才行&#xff0c;crond服务通过crontab命令实现 anacron 无法周期性执行&#xff0c;只能以天为…

C语言实现贪吃蛇(easyx)

1.大一写的贪吃蛇&#xff0c;有兴趣的可以自取&#xff0c;为了大家移植方便没有写头文件&#xff0c;直接复制就可以运行&#xff0c;编译环境是vs2022。 但是运行之前首先要进行两个配置&#xff0c;不然会报错。 1>将字符集改为“使用多字节字符” 2>因为我为游戏…

【C语言】贪吃蛇小游戏代码详解

贪吃蛇的规则大家应该都知道&#xff0c;简单来说就是吃到食物则蛇身增长&#xff0c;蛇可以在游戏区域内随意移动。游戏结束条件就是蛇撞到边界或者撞到自己色蛇身。 首先&#xff0c;实现一个函数&#xff0c;这个函数的作用是将光标移动到我们所期望的位置 /** 控制光标…

乐趣c语言——贪吃蛇

目录 ​ 1.游戏介绍与思路 1.1介绍&#xff1a; 1.2游戏区思路 1.2.1围墙 1.2.2游戏区域 1.2.3蛇头与蛇身 1.3游戏逻辑思路 2.正式实现贪吃蛇 2.1在开始前我们先包头文件和宏定义 2.2创建游戏区并且初始化 2.3初始化蛇头与蛇身 2.4打印与覆盖蛇 2.5实现蛇的移动 2…

C语言制作小游戏——贪吃蛇

直接上代码 ​ #include <stdio.h> #include <stdlib.h> #include <math.h> #include <conio.h> #include <time.h> #include <windows.h>//MAXWIDTH、MAXHEIGHT、INITLEN 以字符记 #define MAXWIDTH (30) #define MAXHEIGHT MAXWIDTH #d…

C语言之贪吃蛇游戏源码

贪吃蛇游戏是我编程以来做的第一个游戏&#xff0c;很兴奋&#xff0c;我记得当时我一直最求代码数量的最小化&#xff0c;即以最少的代码实现功能&#xff0c;有的时候&#xff0c;对换行、括号之类的都下手&#xff0c;呵呵&#xff0c;现在想想都想笑&#xff0c;那些年让我…