数据结构篇:链栈应用(括号匹配)(C++)

很简单,掌握栈的基础知识即可。

#include <iostream>
#include <string.h>
using namespace std;
struct Node {
	int data;
	Node *next;
};
class LinkStack {
	private :
		Node *top;
	public :
		LinkStack() {
			top=NULL;
		}
		~LinkStack();
		void Push(int e);
		int Pop();
		int GetTop();
		void Match(char toBeMatch[],int length);
		bool TestEmpty();
};
LinkStack:: ~LinkStack() {
	while(top) {
		Node *p=new Node;
		p=top->next;
		delete top;
		top=p;
	}
}
int LinkStack::Pop() {
	if(!top) {
		cout<<"溢出"<<endl;
		return -1;
	}
	Node *p=new Node;
	p=top;
	top=top->next;
	delete p;
	return 1;
}
void LinkStack::Push(int e) {
	Node *s=new Node;
	if(!s) {
		cout<<"内存分配失败";
		return ;
	}
	s->data=e;
	s->next=top;
	top=s;
}
int LinkStack::GetTop() {
	if(top) {
		return top->data;
	}
}
void LinkStack::Match(char toBeMatch[],int length) {
	int count=0,state=1;
	while(count<length) {
		char temp=toBeMatch[count];
		switch (temp) {
			case '(':
				Push(1);
				count++;
				break;
			case '[':
				Push(2);
				count++;
				break;
			case ')':
				if(GetTop()==1) {
					Pop();
				} else {
					state=0;
				}
				count++;
				break;
			case ']':
				if(GetTop()==2) {
					Pop();
				} else {
					state=0;
				}
				count++;
				break;
			default : {
				count++;
				break;
			}

		}
	}
	if(state==0||TestEmpty()==false) {
		cout<<"未匹配成功"<<endl;
	} else if(state==1&&TestEmpty()==true) {
		cout<<"匹配成功"<<endl;
	}
}
bool LinkStack:: TestEmpty() {
	if(top) {
		return false;
	} else {
		return true;
	}
}
int main() {
	char toBeMatch[100];
	int length;
	while(true) {
		cout<<"请输入想要匹配的括号(注意只支持英文格式):"<<endl; 
		cin>>toBeMatch;
		cout<<"想要匹配前几个括号?:"<<endl; 
		cin>>length;
		LinkStack linkStack;
		linkStack.Match(toBeMatch,length);
		memset(toBeMatch, 0, sizeof(toBeMatch));
	}
	return 0;
}















 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值