王道考研数据机构:中缀表达式转为后缀表达式

news/2024/7/9 19:35:09 标签: 数据结构, 算法

实现方法: 

        初始化一个栈,用于保存暂时还不能确定运算顺序的运算符。从左到右处理各个元素,直到末尾。可能遇到三种情况:

  1. 遇到操作数。直接加入后缀表达式
  2. 遇到界限符。遇到“(”直接入栈;遇到“)”则依次弹出栈内运算符并加入后缀表达式,直到弹出“(”为止。注意:“(”不加入后缀表达式。
  3. 遇到运算符。依次弹出栈中优先级高于或等于当前运算符的所有运算符,并加入后缀表达式,若磁到“(”或栈空则停止。之后再把当前运算符入栈。

按上述方法处理完所有字符后,将栈中剩余运算符依次弹出,并加入后缀表达式。

#include<stdio.h>
#include<malloc.h>
#define MaxSize 100
typedef struct Stack{
	char data[MaxSize];
	int top;
}Stack;
void initStack(Stack* &S){
	S = (Stack *)malloc(sizeof(Stack));
	S->top=-1;
}
bool push(Stack * &S, char e){
	if(S->top == MaxSize - 1)
		return false;
	S->data[++S->top] = e;
	printf("元素%c进栈\n",e);
	return true;
}
bool pop(Stack * &S,char &e){
	if(S->top==-1)
		return false;
	e = S->data[S->top--];
	printf("元素%c出栈\n",e);
	return true;
}
bool getTop(Stack * &S, char &e){
	if(S->top==-1)
		return false;
	e = S->data[S->top];
	return true;
}
bool emptyStack(Stack * &S){
	return S->top==-1;
}
int getSymbolPriority(char c){
	if(c=='+'||c=='-')
		return 1;
	else
		return 2;
}
int main()
{
	Stack *s;
	char str[MaxSize];//中缀表达式 
	char houZhui[MaxSize];//后缀表达式 
	int index=0;
	scanf("%s",str);
	initStack(s);
	for(int i=0;str[i]!='\0';i++)
	{
		printf("第%d次操作\n",i+1); 
		if(str[i]=='+' || str[i]=='-' || str[i]=='*' || str[i]=='/')
		{
			int v1 = getSymbolPriority(str[i]);
			while(!emptyStack(s))
			{
				char e;
				getTop(s,e);
				if(e=='(')break;
				int v2 = getSymbolPriority(e);
				if(v2>=v1)
				{
					pop(s,e);
					houZhui[index++]=e;
				}
				else
					break;
			}
			push(s,str[i]);
		}
		else if(str[i]=='(' || str[i]==')')
		{
			if(str[i]=='(')
				push(s,str[i]);
			else
				while(!emptyStack(s))
				{
					char e;
					getTop(s,e);
					if(e=='(')
					{
						pop(s,e);
						break;c
					}
					else
					{
						pop(s,e);
						houZhui[index++]=e;
					}	
				}
		}
		else
		{
			houZhui[index++]=str[i];
		}
		printf("此时后缀表达式元素为:");
		for(int j=0;j<index;j++)
			printf("%c",houZhui[j]);printf("\n\n\n"); 
	}
	printf("栈中剩余元素依次弹出:\n");
	while(!emptyStack(s)){
		char e;
		pop(s,e);
		houZhui[index++]=e;
	}
	printf("\n最终结果为:\n");
	for(int i=0;i<index;i++)
		printf("%c",houZhui[i]);
	return 0;
} 
//A+B-C*D/E+F
//A+B*(C-D)-E/F

运行结果:

 输入:

A+B-C*D/E+F

输出:
第1次操作
此时后缀表达式元素为:A

第2次操作
元素+进栈
此时后缀表达式元素为:A

第3次操作
此时后缀表达式元素为:AB

第4次操作
元素+出栈
元素-进栈
此时后缀表达式元素为:AB+

第5次操作
此时后缀表达式元素为:AB+C

第6次操作
元素*进栈
此时后缀表达式元素为:AB+C

第7次操作
此时后缀表达式元素为:AB+CD

第8次操作
元素*出栈
元素/进栈
此时后缀表达式元素为:AB+CD*

第9次操作
此时后缀表达式元素为:AB+CD*E

第10次操作
元素/出栈
元素-出栈
元素+进栈
此时后缀表达式元素为:AB+CD*E/-

第11次操作
此时后缀表达式元素为:AB+CD*E/-F

栈中剩余元素依次弹出:
元素+出栈

A+B-C*D/E+F
转为后缀表达式最终结果为:
AB+CD*E/-F+

 输入:

A+B*(C-D)-E/F

输出

第1次操作
此时后缀表达式元素为:A

第2次操作
元素+进栈
此时后缀表达式元素为:A

第3次操作
此时后缀表达式元素为:AB

第4次操作
元素*进栈
此时后缀表达式元素为:AB

第5次操作
元素(进栈
此时后缀表达式元素为:AB

第6次操作
此时后缀表达式元素为:ABC

第7次操作
元素-进栈
此时后缀表达式元素为:ABC

第8次操作
此时后缀表达式元素为:ABCD

第9次操作
元素-出栈
元素(出栈
此时后缀表达式元素为:ABCD-

第10次操作
元素*出栈
元素+出栈
元素-进栈
此时后缀表达式元素为:ABCD-*+

第11次操作
此时后缀表达式元素为:ABCD-*+E

第12次操作
元素/进栈
此时后缀表达式元素为:ABCD-*+E

第13次操作
此时后缀表达式元素为:ABCD-*+EF

栈中剩余元素依次弹出:
元素/出栈
元素-出栈

A+B*(C-D)-E/F
转为后缀表达式最终结果为:
ABCD-*+EF/-


http://www.niftyadmin.cn/n/5539043.html

相关文章

DP学习——模板模式

学而时习之&#xff0c;温故而知新。 字面理解 模板&#xff1f;啥叫模板&#xff1f;模板就是固定死了&#xff0c;就是一套流程/步骤上层写死了。固定死了的流程或者步骤就是模板。然后我们要重写或者改写的是写死的这套流程中的节点。俗称“套模板”。 使用场合&#xff…

ArcGIS Pro SDK (七)编辑 15 版本控制选项

ArcGIS Pro SDK &#xff08;七&#xff09;编辑 15 版本控制选项 文章目录 ArcGIS Pro SDK &#xff08;七&#xff09;编辑 15 版本控制选项获取和设置版本控制选项 环境&#xff1a;Visual Studio 2022 .NET6 ArcGIS Pro SDK 3.0 获取和设置版本控制选项 var vOptions A…

Symfony配置管理深度解析:构建可维护项目的秘诀

Symfony是一个高度灵活且功能丰富的PHP框架&#xff0c;它提供了一套强大的配置管理系统&#xff0c;使得开发者能够轻松定制和优化应用程序的行为。本文将深入探讨Symfony中的配置管理机制&#xff0c;包括配置的结构、来源、加载过程以及最佳实践。 一、配置管理的重要性 在…

Word中输入文字时,后面的文字消失

当在Word中输入文字时&#xff0c;如果发现后面的文字消失&#xff0c;通常是由以下3个原因造成的&#xff1a; 检查Insert键状态&#xff1a;首先确认是否误按了Insert键。如果是&#xff0c;请再次按下Insert键以切换回插入模式。在插入模式下&#xff0c;新输入的文字会插入…

抖音矩阵智能剪辑系统源码,saas多平台多账号一站式管理,系统搭建流程

‘1. 将MySQL升级至5.6版本&#xff0c;PHP更新至7.2版本&#xff0c;并使用Apache作为服务器。数据库应命名为“juzhen”。 2. 在Nginx环境下&#xff0c;实现伪静态的切换。 3. 将安装包解压至项目的根目录&#xff0c;并定位至application/database.php文件以更换数据库密…

把鼠标光标移到一段文字的首部,尾部,以及翻行查找文字等

如果当前的键盘无单独的End、Home、PgDn、PdUp。 1、如果光标在一段文字的中间&#xff1a; 需要快速移到文字尾部&#xff0c;按住&#xff1a;shiftEnd(如果End在数字1键扣上,shift1&#xff09; 需要快速移到文字首部&#xff1a;按住&#xff1a;shiftHome(如果End在数字…

Kafka系列之Kafka知识超强总结

一、Kafka简介 Kafka是什么 Kafka是一种高吞吐量的分布式发布订阅消息系统&#xff08;消息引擎系统&#xff09;&#xff0c;它可以处理消费者在网站中的所有动作流数据。 这种动作&#xff08;网页浏览&#xff0c; 搜索和其他用户的行动&#xff09;是在现代网络上的许多社…

学习.NET 8 MiniApis入门

介绍篇 什么是MiniApis&#xff1f; MiniApis的特点和优势 MiniApis的应用场景 环境搭建 系统要求 安装MiniApis 配置开发环境 基础概念 MiniApis架构概述 关键术语解释&#xff08;如Endpoint、Handler等&#xff09; MiniApis与其他API框架的对比 第一个MiniApis…