中缀表达式转后缀表达式栈的变化_利用栈实现中缀转后缀

中缀表达式转后缀表达式栈的变化_利用栈实现中缀转后缀这里给出中缀表达式转后缀表达式的算法过程,以及再举两个例子算法过程:1.数字直接加入后缀表达式2.如果是‘(’,入栈3.如果是‘)’,则依次把栈中的运算符加入后缀表达式,直到出现‘(’并从栈中删除它4.如果是运算符+-*/a.栈空或者栈顶元素为‘(’,入栈b.高于栈顶元素优先级,入栈c.否则依次弹出栈顶运算符,直到遇到一个优先级小于它的运算符或者是遇到‘(’为止5.遍历完成后,如果栈非空则依次弹出所有栈顶元素加入到表达式当中例1:…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

这里给出中缀表达式转后缀表达式的算法过程,以及再举两个例子

算法过程:

1. 数字直接加入后缀表达式
2.如果是‘(’, 入栈
3.如果是‘)’, 则依次把栈中的运算符加入后缀表达式,直到出现‘(’并从栈中删除它
4. 如果是运算符 + – * /
    a.栈空或者栈顶元素为‘(’, 入栈
    b.高于栈顶元素优先级,入栈
    c.否则依次弹出栈顶运算符,直到遇到一个优先级小于它的运算符或者是遇到‘(’为止
5.遍历完成后,如果栈非空则依次弹出所有栈顶元素加入到表达式当中

例1:

中缀表达式转后缀表达式栈的变化_利用栈实现中缀转后缀

 

例2:

中缀表达式转后缀表达式栈的变化_利用栈实现中缀转后缀

code:

#include <stdio.h> 
#include <string.h> 

#define MaxSize 100 

typedef struct{
	char data[MaxSize];
	int top; // 栈顶指针 指向栈顶元素 
} SeqStack;

// 顺序栈初始化 
void StackInit(SeqStack s)
{
	s.top = 0;
	memset(s.data, 0, sizeof(s.data));
}
// 入栈 
bool StackPush(SeqStack &s, char e)
{
	if(s.top == MaxSize){
		return false;
	}
	s.data[s.top++] = e;
	return true;
}
// 出栈 
bool StackPop(SeqStack &s)
{
	if(s.top == 0){
		return false;
	}
	s.data[s.top-1] = '\0';
	s.top--;
	return false;
}
// 获取栈顶元素 
char GetTop(SeqStack s)
{
	return s.data[s.top-1];
}
// 判断栈是否为空 
bool StackIsEmpty(SeqStack s)
{
	return (s.top == 0 ? true : false);
}
// 优先级比较 
bool check(char ch1, char ch2) // 只有ch1的优先级小于ch2的优先级时返回true 
{
	if((ch1 == '+' || ch1 == '-') && (ch2 == '*' || ch2 == '/')){
		return true;
	}
	return false;
}
// 三个参数分别时 栈,目标表达式,转换后的结果 
void solve(SeqStack &s, char *str, char *ans)
{
	int idx = 0; // ans的下标 
	int len = strlen(str);
	for(int i = 0; i < len; i++){
		if(str[i] >= '0' && str[i] <= '9'){ // 数字加入表达式 
			ans[idx] = str[i];
			idx++;
		}
		else if(str[i] == '(' || StackIsEmpty(s) || GetTop(s) == '('){ // 栈为空或栈顶为左括号 入栈 
			StackPush(s, str[i]);
		}
		else if(str[i] == ')'){ // 如果为右括号 
			do{
				ans[idx] = GetTop(s);
				idx++; 
				StackPop(s);
			}while(GetTop(s) != '(' );
			StackPop(s); // 删除左括号 
		}
		// 当前元素是运算符 如果优先级高于栈顶元素 入栈 
		else if(check(GetTop(s),str[i])){
			StackPush(s, str[i]);
		}
		else{ // 其他情况->当前元素是运算符且不能入栈 
			do{
				ans[idx] = GetTop(s);
				idx++;
				StackPop(s);
			}while(!(check(GetTop(s), str[i]) || GetTop(s) == '(') ); 
			StackPush(s, str[i]);
		}
	}
	while(!StackIsEmpty(s)){ // 栈内有剩余运算符则加入表达式 
		ans[idx++] = GetTop(s);
		StackPop(s);
	}
	ans[idx] = '\0'; // 确保ans为字符串不会有多余内容 
}

int main()
{
	SeqStack s;
	StackInit(s);
	char str[MaxSize], ans[MaxSize] = {0};
	scanf("%s", str);
	solve(s, str, ans);
	printf("%s\n", ans);
	
	return 0;
}

Jetbrains全家桶1年46,售后保障稳定

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/226774.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 音乐播放器源代码(免费复制)「建议收藏」

    音乐播放器源代码(免费复制)「建议收藏」音乐播放器源代码(免费复制)

    2022年6月26日
    61
  • IOS 与ANDROID框架及应用开发模式对照一[通俗易懂]

    IOS 与ANDROID框架及应用开发模式对照一

    2022年1月20日
    145
  • android错误之android.content.res.Resources$NotFoundException:

    错误:android.content.res.Resources$NotFoundException: String resource ID #0x1原因:一般发生在参数 int resId 错误,你把String赋值给int的resId,所以编译器找不到正确的resource于是报错。最简单的例子,检查一下你的Toast.makeText()啊textView.setText啊之类的函数

    2022年3月10日
    35
  • 软件测试方法中黑盒测试法主要用于测试_黑盒测试一般由谁完成

    软件测试方法中黑盒测试法主要用于测试_黑盒测试一般由谁完成黑盒(又叫功能测试、数据驱动测试):1.黑盒测试发现错误类型:功能错误和遗漏界面错误数据库错误性能错误初始化和终止错误2.黑盒测试:程序外部接口进行的3.黑盒测试就是根据功能需求来设计测试用例,验证软件是否按照预期要求工作。4.黑盒测试技术主要有等价类划分法、边界值法、判定表法、因果图法、场景法等。5.等价类划分法测试技术是依据软件系统输入集合、输出集合或操作集合实现功能的相同性为依据,对其进行的…

    2022年10月3日
    0
  • Java大数据学习01–大数据的本质及学习顺序介绍

    Java大数据学习01–大数据的本质及学习顺序介绍随着互联网的使用人数越来越多,产生的数据也越来越多。根据数据我们可以分析出很多有用的信息。这也就是当前为什么大数据这么火的行为。学习大数据有很多种方式,但我们学习的载体是以目前最普遍,最流行的Java语言来进行学习。下面我们进入正题:1、首先是大数据的本质:大数据的本质无非两条:大数据的存储(Hadoop)和大数据的计算(Spark)存储:由于数据量巨大,把所有数据存在一个机器…

    2022年5月28日
    36
  • 手把手实现Java图书管理系统(附源码)_图书管理系统项目背景

    手把手实现Java图书管理系统(附源码)_图书管理系统项目背景基于JavaWeb开发的图书管理系统实现功能数据库运行环境图书馆作为一种信息资源的集散地,图书和用户借阅资料繁多,包含很多的信息数据的管理,现今,有很多的图书馆都是初步开始使用,甚至尚未使用计算机进行信息管理。图书馆信息管理作为计算机应用的一个分支,有着手工管理无法比拟的优点,如检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点很大程度的提高了管理图书馆信息的工作效率,节省了大量资金,方便了师生对图书的借阅和归还。图书馆管理系统代表了图书馆管理的信息化,不仅是体现图书馆现代化形

    2022年9月15日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号