11111

#include<stdio.h>
#include<stdbool.h>
#include <string.h>
#include <stdlib.h>
#define MaxSize 50
#define _CRT_SECURE_NO_WARNINGS 
typedef struct {
	char data[MaxSize];
	int top;
}SqStack;
void InitStack(SqStack *S){
	S->top = -1;
}
bool StackEmpty(SqStack S)
{
	if (S.top == -1)
		return true;
	else
		return false;
}
bool Push(SqStack *S, char x)
{
	if (S->top == MaxSize - 1)
		return false;
	S->top += 1;
	S->data[S->top] = x;
	return true;
}
bool Pop(SqStack* S, char* x)
{
	if (S->top)
		return false;
	*x = S->data[S->top];
	S->top -= 1;
	return true;
}
bool check(char str[], int length)
{
	int i;
	SqStack S;
	InitStack(&S);
	for (i = 0; i < length; i++)
	{
		if (str[i] == '(' || str[i] == '[' || str[i] == '{')
		{
			Push(&S, str[i]);
		}
		else
		{
			if (StackEmpty(S))
			{
				return false;
			}

		}
		char topelem;
		if (str[i] == ')' && topelem == '(')
		{
			return false;
		}
		else if (str[i] == '}' && topelem != '{')
		{
			return false;
		}
		else if (str[i] == ']' && topelem != '[')
		{
			return false;
		}
	}
	return StackEmpty(S);
}
int main() {
	char s[MaxSize];
	printf("请输入需要判断的括号:\n");
	scanf("%s", s);
	int len = strlen(s);
	printf("当前输入的括号个数为:%d\n", len);
	printf("--------现在开始进行判断--------\n");
	if (check(s, len)) {
		printf("匹配成功!");
	}
	else {
		printf("匹配失败!");
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值