数据结构入门系列——用栈解决实际问题(1)

一、判断回文

判断一条字符串是否为回文

bool Panduan(char *st, int n)  //n为字符串长度
{
	int i = 0;
	lnode *top = new lnode;
	top = InitStack();
	while (i < n)
	{
		Push(top, st[i++]);
	}
	i = 0; 
	//char *data=new char;//若为*,则必须初始化
	char data;
	while (!StackEmpty(top))
	{
		Pop(top, &data);
		if (data != st[i++])
			return 0;
		return 1;
	}
}
void main()
{
	cout << "please input the length of string:" << endl;
	int n;
	cin >> n;
	char *st = new char[n];
	cout << "please input the string:" << endl;
	for (int i = 0; i < n; i++)
	{
		cin >> st[i];
	}
	cout << "判断是否为回文数:" << endl;
	cout << Panduan(st, n);
}

二、匹配括号

用栈来实现一个表达式中的‘(’,‘[‘, ’)’, ’]’, ’{ ‘,’ }’是否匹配。

bool Match(char *st, int n)
{
	lnode *top;
	top = InitStack();
	int flag = 1, i = 0;
	char data;
	while (i < n&&flag)
	{
		switch (st[i])
		{
		case '(':case '[':case '{':
			top = Push(top, st[i]);
			break;
		case ')':
			if (!GetTop(top, data) || data != '(')
				flag = 0;
			top = Pop(top, &data);
			break;
		case ']':		//判断栈顶是否为'['
			if (!GetTop(top, data) || data != '[')	  //出栈操作失败或不匹配
				flag = 0;
			top = Pop(top, &data);
			break;
		case '}':		//判断栈顶是否为'{'
			if (!GetTop(top, data) || data != '{')	  //出栈操作失败或不匹配
				flag = 0;
			top = Pop(top, &data);
			break;
		default :
			break;
		}
		i++;
	}
	if (StackEmpty(top) && flag == 1)
		return 1;
	else return 0;
}
void main()
{
	int n;
	cout << "请输入表达式长度:";
	cin >> n;
	cout << "请输入表达式:" << endl;
	char *st = new char[n];
	for (int i = 0; i < n; i++)
		cin >> st[i];
	cout << "判断是否匹配:(“1”表示匹配,“0”表示不匹配)" << endl;
	cout << Match(st, n) << endl;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值