括号匹配C语言实现

article/2025/10/25 19:06:55

若你掌握以下知识,你可以更好地理解此篇文章:
1.C语言基本语法。
2.栈的核心思想与栈的构建。

分割线/

相信看此篇文章的朋友很多是从书本过来的,书本那段描述真的晦涩难懂,什么紧迫性123456的,什么被需要,被满足。。。。我这里先简单说一下括号匹配的思路是怎么样的。括号匹配有点像俄罗斯方块,或者消消乐,怎么说呢,我给大家用图演示一个过程就知道了

1.首先准备一个数组装要匹配的括号们,再准备一个栈。

在这里插入图片描述
2.然后把数组内第一个括号丢入栈里

在这里插入图片描述
3.丢了以后是这样
在这里插入图片描述

4.再丢数组内第二个括号

在这里插入图片描述
5.丢数组内第三个

在这里插入图片描述
6.丢第四个

在这里插入图片描述
7.丢第五个

在这里插入图片描述
发现匹配,然后就消消乐

在这里插入图片描述
消除后:

在这里插入图片描述
8.丢第六个

在这里插入图片描述
9.丢第七个

在这里插入图片描述
发现匹配,需要消除:

在这里插入图片描述
消除后:

在这里插入图片描述
9.丢第八个括号

在这里插入图片描述
发现匹配,消除,这里就不圈出来了。消除后的:

在这里插入图片描述
10.丢第九个括号入栈:

在这里插入图片描述
匹配,消除:

在这里插入图片描述
11.丢第10个括号入栈

在这里插入图片描述
匹配,消除:

在这里插入图片描述
现在栈是空的了,证明括号匹配。读者可以按这个思路,在草稿纸上拿其他括号序列来实验一下。

——————分割线——————

接下来给大家讲解一下写程序的思路:

1.首先把装括号序列的数组写上

#include<stdio.h>
#include <string.h>
#define length 100int main(){char array[length] = {'[','(','[',']','[',']',')',']'};	
}

2.再创建一个栈

#include<stdio.h>
#include <string.h>
#define length 100char *top;	//指针,指向栈顶的char push(char bracket)		//压栈操作 
{top = top+1;*(top) = bracket;
}void pop()			//出栈操作,待会匹配的时候,调用这个函数把匹配的两个括号弹出 
{top = top-2;
}int main(){char array[length] = {'[','(','[',']','[',']',')',']'};	char stack[length];
}

3.把核心函数补全:

#include<stdio.h>
#include <string.h>
#define length 30
char *top;
char push(char bracket)
{top = top+1;*(top) = bracket;
}
void pop()
{top = top-2;
}
int main(){
//先写一个数组char array[length] = {'[','(','[',']','[',']',')',']'};		//创建一个数组装括号序列 char stack[length];		//数组,用来做栈的空间 int stack_length = strlen(array);	//计算数组里的括号个数,待会控制for轮次的时候用的 top = stack - 1;		//先把top指向栈的-1层。可能有人会问,不是一开始要指向栈的0吗?因为待会压栈的时候正好 -1 + 1 = 0,指向0,正好可以往stack[0]里面赋值 for(int i = 0;i<stack_length;i++)		//循环 {	push(array[i]);		//还记得刚刚的流程演示吗?无论如何,每一个步骤都先把数组里的括号压入栈里 if(array[i] == ']'){	//如果压入的是 ] 号, if(*(top-1) == '['){	//就在当前位置往下一个单位判断有没有 [ 号,如果有,就弹出栈 pop();}}if(array[i] == ')'){if(*(top-1) == '('){pop();}}if(array[i] == '}'){if(*(top-1) == '{'){pop();}}}		if(top == stack-1){printf("括号匹配"); }else{printf("括号不匹配");}
}

///至此教程结束///

如果这篇教程帮到你,可以点赞支持一下,非常感谢 ( ̄▽ ̄)"


http://chatgpt.dhexx.cn/article/yTF4FISK.shtml

相关文章

c语言括号匹配的检验,检验括号匹配的算法

用栈实现检验括号匹配的算法没啥具体描述&#xff0c;数据结构的知识&#xff0c;急用&#xff0c;有重赏 思想是 先进栈&#xff0c;获取第一个半边括号&#xff0c;标记一下&#xff0c;继续进栈直到获取到第二个与之匹配的另一外括号&#xff0c;然后出栈&#xff0c;取出内…

栈和括号匹配

栈是一种符合先进后出原则的数据结构 主要操作氛围进栈和弹栈。规则是栈顶元素先弹出而后进栈&#xff0c;进栈就是一个新的元素取代原本的栈顶元素。 栈可以用来进行最基本的括号匹配操作&#xff0c;栈的图示为&#xff1a;&#xff08;转载&#xff09; 具体代码如下 //定…

C++ 括号匹配

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

栈以及括号匹配

栈以及括号匹配 一、栈&#xff1a;二、定义&#xff1a;三、入栈&#xff1a;四、出栈&#xff1a;五、测试代码&#xff1a;六、括号匹配七、测试代码八、总代码九、测试结果 一、栈&#xff1a; 栈&#xff08;stack&#xff09;又名堆栈&#xff0c;它是一种运算受限的线性…

括号匹配问题详解

直接看题&#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>因为我为游戏…