数据结构(栈):中缀表达式转后缀表达式题型的快速图解法(求栈中操作符等)

本文主要是介绍数据结构(栈):中缀表达式转后缀表达式题型的快速图解法(求栈中操作符等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2024/5/14:

        学编译原理的时候接触到了递归树的画法,中缀转后缀的解题过程和编译原理中的递归树有异曲同工之妙。今日解题的时候想了一下图解法,遂记录,本质上是对递归树的改进。

 图解原理概述

        以表达式 a+b*(c-d)+e 为例,先将其转化为二叉树,转化过程暂且不表,请读者自搜。总之能画成以下这样,若要得出后缀表达式则请后序遍历此树:

图1 基本结构图

        以上为构造的基本结构,跟普通的树不同的是里面增加了带括号的2型特殊节点。而红线即为递归的过程。

        对于1型节点来说,递归(红线)到1号位时,符号栈中增加该符号,而到2号位时出栈;而对于2型节点来说,递归(红线)到1号位时,符号栈中增加左括号,而到2号位时增加该符号,到3号位时弹出之前入栈的左括号和符号。各位仔细理解一下可以发现这和算法的处理方式是相同的。


例题

【2012年统考真题】已知操作符包括‘+’‘-’‘’‘/’‘(’‘)’ 。将中缀表达式a + b - a ( ( c + d ) / e - f ) + g转化为等价的后缀表达式a b + a c d + e / f - * - g + 时,用栈来存放暂时还不能确定运算次序的操作符。若栈初始时为空,则转换过程中同时保存在栈中的操作符的最大个数是()

A. 5              B. 7              C. 8               D. 11

常规解法:见答案,可以看到正常写挺麻烦的。

图解法

        图2 例题图解法答案

        简单画一画可以看到递归(红线)到最下面的2时同时保存在栈中的操作符最多,此时栈中元素为 - * ( ( + 一共五个,故选A

【2015统考真题】假设栈初始为空,将中缀表达式a/b+(c*d-e*f)/g转化为等价的后缀表达式的过程中,当扫描到 f 时,栈中的元素依次是()

A. +(*-              B. +(-*             C. /+(*-*             D. /+-*

        此题同样可用图解法作答,望读者自行思考(其实是我懒得写了)。


结尾

        希望对大家的学习有所启发。

这篇关于数据结构(栈):中缀表达式转后缀表达式题型的快速图解法(求栈中操作符等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/990790

相关文章

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

SpringBoot @Scheduled Cron表达式使用方式

《SpringBoot@ScheduledCron表达式使用方式》:本文主要介绍SpringBoot@ScheduledCron表达式使用方式,具有很好的参考价值,希望对大家有所帮助,如有... 目录Cron 表达式详解1. 表达式格式‌2. 特殊字符解析3. 常用示例‌4. 重点规则5. 动态与复杂场景‌

Spring Boot 集成 Quartz 使用Cron 表达式实现定时任务

《SpringBoot集成Quartz使用Cron表达式实现定时任务》本文介绍了如何在SpringBoot项目中集成Quartz并使用Cron表达式进行任务调度,通过添加Quartz依赖、创... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Python如何快速下载依赖

《Python如何快速下载依赖》本文介绍了四种在Python中快速下载依赖的方法,包括使用国内镜像源、开启pip并发下载功能、使用pipreqs批量下载项目依赖以及使用conda管理依赖,通过这些方法... 目录python快速下载依赖1. 使用国内镜像源临时使用镜像源永久配置镜像源2. 使用 pip 的并

SpringBoot快速接入OpenAI大模型的方法(JDK8)

《SpringBoot快速接入OpenAI大模型的方法(JDK8)》本文介绍了如何使用AI4J快速接入OpenAI大模型,并展示了如何实现流式与非流式的输出,以及对函数调用的使用,AI4J支持JDK8... 目录使用AI4J快速接入OpenAI大模型介绍AI4J-github快速使用创建SpringBoot

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import