数据结构 栈

栈的相关操作

栈的结构

typedef struct
{
	char* top;
	char* base;
	int stacksize;
}Stack;

栈的初始化

void Initstack(Stack *s)
{
	s->base=(char *)malloc(sizeof(char)*Initsize);
	s->top=s->base;
	s->stacksize =Initsize;
}

入栈

void push(Stack *s,char ch)
{
	if(s->top-s->base==s->stacksize )
	{
		printf("栈已满,追加空间");
		s->base=(char *)realloc(s->base,sizeof(char)*(Initsize+10));
		s->top=s->base+s->stacksize;
		s->stacksize=Initsize+10;
	}
	*(s->top)=ch;
	s->top++;
}

出栈

void pop(Stack *s,char *ch)
{
	if(s->top==s->base)
	{
		printf("栈为空");
		return;
	}
	s->top--;
	*ch=*(s->top);
}

判断栈是否为空

bool empty(Stack s)
{
	if(s.top==s.base)
	return true;
	return false;
}

栈的应用

有效的括号

括号不匹配的情况有三种:
1.左右括号不匹配
2.缺少左括号
3.缺少右括号

全部代码

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<string.h>
#include<ctype.h>
#define Initsize 30
typedef struct
{
	char* top;
	char* base;
	int stacksize;
}Stack;
void Initstack(Stack *s)
{
	s->base=(char *)malloc(sizeof(char)*Initsize);
	s->top=s->base;
	s->stacksize =Initsize;
}
void push(Stack *s,char ch)
{
	if(s->top-s->base==s->stacksize )
	{
		printf("栈已满,追加空间");
		s->base=(char *)realloc(s->base,sizeof(char)*(Initsize+10));
		s->top=s->base+s->stacksize;
		s->stacksize=Initsize+10;
	}
	*(s->top)=ch;
	s->top++;
}
void pop(Stack *s,char *ch)
{
	if(s->top==s->base)
	{
		printf("栈为空");
		return;
	}
	s->top--;
	*ch=*(s->top);
}
bool empty(Stack s)
{
	//栈为空,返回1,否则返回0 
	if(s.top==s.base)
	return true;
	return false;
}
char gettop(Stack s)
{
	return *(--s.top);
}
//括号匹配问题 
bool bracketMatching(char *paraString)
{
	int len=strlen(paraString);
	int i;
	Stack s;
	Initstack(&s);//初始化辅助栈 
	char ch,p;
	for(i=0;i<len;i++)
	{
		switch(paraString[i])
		{
			case '{':
			case '[':
			case '(':
				push(&s,paraString[i]);
				break;
			case '}':
				pop(&s,&ch);
				if(empty(s)==false||ch!='{')//缺少左括号或者括号不匹配返回0 
				return false;
				break;
			case ']':
				pop(&s,&ch);
				if(empty(s)==false||ch!='[')
				return false;
				break;
			case ')':
				pop(&s,&ch);
				if(empty(s)==false||ch!='(')
				return false;
				break;
			default://当是数字或者符号的时候直接跳过 
				break;
		}
	}
	if(empty(s)==0)//栈不为空也就是缺少右括号的情况return 0 
	return false;
	return true; 
}

 
int main()
{
	char str[100];
	printf("输入一个多项式\n");
	gets(str);
	bool temp=bracketMatching(str);
	printf("多项式%s括号是否匹配(%d)",str,temp);
	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值