首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

C语言括号匹配(栈括号匹配c语言)

大家好,又见面了,我是你们朋友全栈君。 给定一串字符,不超过100个字符,可能包括括号、数字、字母、标点符号、空格,编程检查这一串字符中( ) ,[ ],{ }是否匹配。...输入样例1: sin(10+20) 输出样例1: yes 输入样例2: {[}] 输出样例2: no 思路:题目输入一些字符串,我们就先保留括号之类,判断是否匹配。...如果遇到左括号,就入栈,如果遇到一个右括号,就与栈顶元素比较,如果匹配,出栈,就继续重复操作,直到字符串没有了。期间一旦出现不匹配括号对就直接输出no ,如果栈空了,说明匹配了,就输出yes。...{ if(check(stack[top-1],s[i]))//如果匹配,那么栈顶下移,继续执行下一次新for循环。...因为不是在for循环中结束,说明都匹配成功了,但会出现特殊情况比如((()),令栈不为空。所以是否括号匹配成功不仅要判断是否右括号都有左括号使其匹配,还需要判断栈是否为空。

2.6K20

实现括号匹配算法(括号匹配检验算法完整程序)

实现括号匹配算法(顺序表) 括号匹配问题 假设一个算术表达式中包含圆括号、方括号和花括号三种类型括号,编写一个函数,用来判别表达式中括号是否正确配对,并设计一个测试主函数。...【算法思想】 在算术表达式中,右括号和左括号匹配次序正好符合后到括号要最先被匹配“后进先出”堆栈操作特点,因此可以借助一个堆栈来进行判断。...括号匹配共有以下4种情况: 左、右括号配对次序不正确; 右括号多于左括号; 左括号多于右括号: 左、右括号匹配正确。...具体方法如下:顺序扫描算术表达式(表现为一个字符串),当遇到3种类型括号括号时,让该括号进栈。...当扫描到某一种类型括号时,比较当前栈顶括号是否与之匹配,若匹配,则退栈继续进行判断:若当前栈顶括号与当前扫描括号不相同,则左、右括号配对次序不正确;若字符串当前为某种类型右括号而堆栈已空,则右括号多于左括号

1.6K20

括号匹配问题 栈c语言(c语言栈实现括号匹配)

例如:{}[()]、{[()]}、()[]{}这种大中小括号成对出现(位置不限)则为括号匹配,反之则不匹配,如{()[ 接下来看一下实现方式 栈定义以及相关操作 //栈定义 typedef struct...isEmpty(s)){ *x=s->elem[s->top]; return 1; } else return 0; } 括号处理 括号匹配思想:依次从左至右检查字符串,若为左括号...//成对左右括号ASCII码相差1或者2,以此结论来判断左右括号是否成对出现 int match(char a,char b){ if(a+1==b||a+2==b)//成对左右括号...(&s))//如果栈空,则括号匹配 return 1; else//反之,则不匹配 return 0; } 完整代码 #include #include<stdlib.h...(&s))//如果栈空,则括号匹配 return 1; else//反之,则不匹配 return 0; } int main(){ int n; char a[25]; scanf

2.8K10

python实现括号匹配

主要思路: 首先设置两个列表分别存放是各种括号括号和闭括号,然后遍历给定字符串,分如下几种情况: 1.字符串首字符出现在闭括号列表中,直接结束,输出错误 2.字符串长度不为偶数,直接结束,输出错误...3.对原始字符串列表化去重,如果去重后列表长度不为偶数直接结束,输出错误 4,遍历字符串,将属于开括号集合括号加入到列表中,当遇上一个闭括号时候计算该闭括号在闭括号列表中索引与当前列表最后一个开括号在开括号列表中索引是否一致...,一致则继续,否则直接结束,输出错误 主要是在长度很大时候可以尽快判断一些比较明显错误模式,节省时间 #!...usr/bin/env python # encoding:utf-8 def bracket_mathch(one_str): ''''' 括号匹配 ''' tmp_list

2.2K10

算法:括号匹配问题

还记得有一次笔试题,有一道括号匹配算法题,当时没有学习数据结构和算法,思路很模糊,后来了解一些数据结构之后就有思路了,今天将解法写出来。...false:未正确使用括号字符。 1、分析 如果了解数据结构,那么应该知道,简单采用一个栈特性,就能解决该问题,左括号栈顶字符必须和第一个入栈括号字符匹配。...声明了几个变量: BRANKETS:由配对括号组成字典,注意使用右括号作为key,因为我们要判断是右括号是否与左括号匹配,在字典中找出与key对应value简单,要是找value对应key要复杂一些...使用string类型变量bracketLeft和bracketRight来存储左括号和右括号,判断右括号与左括号匹配方法是:先在bracketRight找到该字符索引,然后对比栈顶字符和bracketLeft...相同索引处字符是否匹配

1.8K10

应用----括号匹配问题

应用----括号匹配问题(这里借鉴朱战立老师算法思想) 一、问题引入: 假设一个算数表达式种包含圆括号、方括号和花括号三种类型括号,编写一个函数,用来判别表达式中括号是否正确配对。...二、算法思想: 括号匹配共有以下4种情况: 左右括号配对次序不正确 左括号多于右括号括号多于左括号 左右括号匹配成功 具体实现方法:顺序扫描算术表达式(表现为一个字符串),当遇到3种类型括号时...当扫描到某一种类型括号时,比较当前栈顶括号是否与之匹配,若匹配,则退栈继续进行判断:若当前栈顶符号与当前扫描括号不相同,则左、右括号配对次序不正确。...若字符串当前为某种类型括号而堆栈已空,则右括号多于左括号;字符串循环扫描结束时,若堆栈非空(即堆栈中还有某种类型左括号),则说明左括号多于右括号;如果未出现上述3种情况,则说明左右括号匹配正确。...= NULL) { return 1; } else { return 0; } } //括号匹配 void bracket(char exp[], int n) { //判断有n个字符字符串

69320

nyoj-括号匹配问题

括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述现在,有一行括号序列,请你检查这行括号是否配对。...后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S长度小于10000,且S不是空串),测试数据组数少于5组。...数据保证S中只含有"[","]","(",")"四种字符输出每组输入数据输出占一行,如果该字符串中所含括号是配对,则输出Yes,如果不配对则输出No样例输入 3 [(]) (]) ([[]()])...样例输出 No No Yes 来源网络上传者naonao问题分析----这种问题一般是从里到外进行配对比如第三个(【【】()】)先进行里面的判断【】()两个配对,所以剪掉,形成新链表(【】)再判断【...】,显然配对所以剩下(),依次这样最后得到head(指针)为NULL,如果最后为NULL,则作为完全匹配,否则作为不完全配对......实现代码: (c语言版)由于c++sTL写,太简单了,就不写了;

93960

【stack使用-括号匹配问题】

1、问题: Java实现括号是否匹配(给定一串字符串看括号是否成对出现) ​​​​​​​思路: 1.1、将字符串每个字符进行遍历 1.2、如果发现是左括号,那么将该字符压入到栈中 1.3、如果是右括号...,先去存储好栈顶找到相应值 1.4、若栈为空返回false,若匹配,pop该左括号,若不匹配也返回false 1.5、最后看存储栈中括号是否都匹配上了,也就是栈最后为空,返回true,否则返回...false 2、代码 package com.liuy; import java.util.HashMap; import java.util.Map; import java.util.Stack;.../** * Java实现括号是否匹配(给定一串字符串看括号是否成对出现) * * 1、将字符串每个字符进行遍历 2、如果发现是左括号,那么将该字符压入到栈中 3、如果是右括号,先去存储好栈顶找到相应值...4、若栈为空返回false,若匹配,pop该左括号,若不匹配也返回false 5、最后看存储栈中括号是否都匹配上了,也就是栈最后为空,返回true,否则返回false * @author Liuy

1.1K51

括号匹配算法「建议收藏」

概述 ​ 括号匹配在很多字符串处理场景中时常被用到,诸如各大IDE括号匹配错误提示,编译器编译时检查应该成对出现括号是否符合要求等,在这里我们就直接使用一种比较常规,但效率不差方法去解决括号匹配问题就行了...栈方法匹配问题 ​ 为了方便描述,对于需要做匹配两个符号,比如’(‘和’)’,前者可称为左侧符号,后者可称为右侧符号。...在做符号匹配时,如果以左侧符号为标准,左侧符号需要右侧符号来完成匹配,但是由于诸如括号这类符号可以做嵌套,所以左侧符号之后既能有左侧符号,也能有右侧符号,处理起来很麻烦。...以右侧符号为标准就没有这个问题了,每一个右侧符号都需要一个左侧符号来匹配,并且要求该右侧符号之前最近一个符号必须是相匹配左侧符号,这样处理起来就方便多了。 ​...定义一个栈,用以记录遍历到当前位置时,所遇到左侧符号,处理方式是这样,每当遇到一个右侧符号时,检查栈是否为空,若此时栈不为空,则对栈进行pop操作表明顶部元素已被匹配,否则为不匹配情况,直接返回false

64210
领券