【数据结构】栈的应用 括号匹配

前端之家收集整理的这篇文章主要介绍了【数据结构】栈的应用 括号匹配前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

括号配对问题:


假设一个表达式中包含三种类型的括号:(),{ },【】,嵌套顺序任意

{ 【()()】 }

1 2 3 4 5 6 7 8

引入“期待的急迫程度”概念,例如当接受第一个括号 { ,则它期待与第8个 } 匹配,然而当接受到第二个 【 时,此时【最期待和第七个 】 匹配。


#ifndef _MATCH_H_
#define _MATCH_H_

#include<iostream>
#include <malloc.h>  
#include <string.h>  
#include<assert.h>//断言

using namespace std;

#define MAXLEN 100
typedef char ElemType;

typedef struct node
{
	ElemType data;
	struct node *next;
}Node,*LinkStack;

void InitStack(LinkStack *stack);//将链栈初始化  
bool StackEmpty(LinkStack stack);//判断链栈是否为空  
ElemType* GetTop(LinkStack stack,ElemType *e);//取栈顶元素  
bool PushStack(LinkStack stack,ElemType e);//进栈操作  
bool PopStack(LinkStack stack,ElemType *e);//出栈操作  
int StackLength(LinkStack stack);//求表长操作  
void DestroyStack(LinkStack stack);//销毁链表  
bool Match(ElemType e,ElemType ch);//判断括号 


#endif

#include "match.h"

void InitStack(LinkStack *stack)//将链栈初始化 
{
	if ((*stack = (LinkStack)malloc(sizeof(stack))) == NULL)
	{
		exit(-1);
	}
	(*stack)->next = NULL;
}


bool StackEmpty(LinkStack stack)//判断链栈是否为空
{
	if (NULL == stack->next)
		return true;
	else
		return false;
}


ElemType* GetTop(LinkStack stack,ElemType *e)//取栈顶元素  
{
	Node *p = stack->next;

	if (!p)
	{
		return NULL;
	}

	*e = p->data;
	return e;
}


bool PushStack(LinkStack stack,ElemType e)//进栈操作  
{
	Node*s = (Node *)malloc(sizeof(Node));
	if (NULL == s)
		return false;

	s->data = e;
	s->next = stack->next;
	stack->next = s;

	return true;
}


bool PopStack(LinkStack stack,ElemType *e)//出栈操作 
{
	Node *p = stack->next;

	if (StackEmpty(stack))
	{
		cout << "EmptyStack"<<endl;
		return false;
	}

	stack->next = p->next;
	*e = p->data;
	free(p);
	p = NULL;

	return true;
		
}


void DestroyStack(LinkStack stack)//销毁链表  
{
	Node *p = stack;
	Node *q  = NULL;
	
	while (!p)
	{
		q = p;
		p = p->next;
		free(q);
		q = NULL;
	}
}

bool Match(ElemType e,ElemType ch)//判断括号 
{
	if ( ('(' == e)  &&  (')'== ch) )
		return true;
	else if ( ('{' == e) && ('}' == ch) )
		return true;
	else if ( ('[' == e) && (']' == ch) )
		return true;
	else
		return false;
}

#include "match.h"

int main(void)
{
	char *p;
	ElemType e;
	ElemType ch[MAXLEN];
	LinkStack s;

	InitStack(&s);

	cout << "Please input the expression with bracket('()','{}','[]')" << endl;

	gets_s(ch);
	p = ch;
	while (*p)
	{
		switch (*p)
		{
		case '(':
		case '[':
		case '{':
			PushStack(s,*p++);
			break;

		case ')':
		case ']':
		case '}':
			if ( StackEmpty(s) )
			{
				cout << "miss left bracket!" << endl;
				return 0;
			}

			else
			{
				GetTop(s,&e);		/*栈不为空 读取的是右括号 则取出栈顶括号*/
				if (Match(e,*p))    /*判断栈顶括号是否为右括号*/
				{
					PopStack(s,&e);/*若栈顶括号和右括号匹配,则栈顶括号出栈*/
				}
					 
				else                /*不匹配*/
				{
					cout << "not match" << endl;
					return 0;
				}
			}
	
		default:
			p++;
		}
	}
	

	if (StackEmpty(s))
		cout << "bracket match!" << endl;
	else
		cout << "not match,miss right bracket" << endl;
	return 0;
}

猜你在找的数据结构相关文章