当前位置: 首页 > news >正文

电商商城网站建设方案wordpress博客xiu

电商商城网站建设方案,wordpress博客xiu,建设管理网站,网站建设推广价格C实现中缀表达式转后缀表达式及后缀表达式的计算 在C中,实现中缀表达式转换为后缀表达式(逆波兰表达式)以及后缀表达式的计算是一个非常经典的问题。它不仅涉及到栈(Stack)数据结构的使用,还涉及到对运算符…

C++实现中缀表达式转后缀表达式及后缀表达式的计算

在C++中,实现中缀表达式转换为后缀表达式(逆波兰表达式)以及后缀表达式的计算是一个非常经典的问题。它不仅涉及到栈(Stack)数据结构的使用,还涉及到对运算符优先级的处理。本文将详细介绍如何实现这一过程,并提供完整的代码实现。


一、中缀表达式转后缀表达式

中缀表达式(如 9+8*(7-6)-5/4)是我们日常使用的表达式形式,其中运算符位于操作数之间。而后缀表达式(逆波兰表达式)是一种不需要括号来标识优先级的表达式形式,运算符位于操作数之后(如 9 8 7 6 - * + 5 4 / -)。

将中缀表达式转换为后缀表达式的算法基于栈结构,主要步骤如下:

  1. 初始化:创建一个空栈用于存储运算符,创建一个空字符串(或列表)用于存储后缀表达式的结果。
  2. 遍历中缀表达式:从左到右依次处理中缀表达式中的每个字符。
    • 如果是操作数(数字),直接添加到后缀表达式中。
    • 如果是左括号 '(',直接压入栈中。
    • 如果是右括号 ')',则依次弹出栈顶运算符并添加到后缀表达式中,直到遇到左括号 '(',此时丢弃这对括号。
    • 如果是运算符(+-*/):
      • 如果栈为空,或栈顶是左括号 '(',或当前运算符优先级高于栈顶运算符,则将当前运算符压入栈中。
      • 否则,依次弹出栈顶运算符并添加到后缀表达式中,直到栈为空或栈顶运算符优先级低于当前运算符,然后将当前运算符压入栈中。
  3. 处理剩余运算符:遍历结束后,如果栈中仍有运算符,依次弹出并添加到后缀表达式中。

二、后缀表达式的计算

后缀表达式的计算同样基于栈结构,主要步骤如下:

  1. 初始化:创建一个空栈用于存储操作数。
  2. 遍历后缀表达式:从左到右依次处理后缀表达式中的每个字符。
    • 如果是操作数(数字),直接压入栈中。
    • 如果是运算符(+-*/):
      • 弹出栈顶的两个操作数,注意后弹出的操作数是第一个操作数。
      • 根据运算符对两个操作数进行计算,将结果压入栈中。
  3. 最终结果:遍历结束后,栈顶的元素即为最终计算结果。

三、代码实现

以下是完整的C++代码实现,包括中缀表达式转后缀表达式以及后缀表达式的计算。代码中还包含了调试信息的输出,方便理解每一步的操作。

#include <iostream>
#include <vector>
#include <string>
#include <stack>
#include <functional>
using namespace std;template<typename T>
void printVec(const string& msg, const vector<T>& vec)
{cout << msg << " | ";for (auto &v : vec)cout << v << '\t';cout << endl;
}// 中缀表达式转后缀表达式
string MidToRear(const string& mid)
{string rear; // 后缀表达式vector<char> stk; // 运算符栈// 定义优先级比较函数function<bool(const char&, const char&)> isPriorOperator = [](const char& A, const char& B){if (A == '-' || A == '+')return false;return B == '-' || B == '+';};for (const char& ch : mid){if (isdigit(ch)) // 如果是数字,直接加入后缀表达式{rear += ch;}else if (ch == '(') // 左括号直接入栈{stk.push_back(ch);}else if (ch == ')') // 右括号,弹出栈顶元素直到遇到左括号{while (stk.back() != '('){rear += stk.back();stk.pop_back();}stk.pop_back(); // 弹出左括号}else if (stk.empty() || isPriorOperator(ch, stk.back()) || stk.back() == '(') // 当前运算符优先级高或栈顶是左括号{stk.push_back(ch);}else // 当前运算符优先级低,弹出栈顶元素直到优先级合适{while (!stk.empty() && stk.back() != '(' && !isPriorOperator(ch, stk.back())){rear += stk.back();stk.pop_back();}stk.push_back(ch);}// 输出当前状态cout << "current ch: " << ch << "\trearExp: \t" << rear << endl;printVec("STACK:", stk);}// 处理栈中剩余的运算符while (!stk.empty()){rear += stk.back();stk.pop_back();}return rear;
}// 计算后缀表达式
double CalRear(const string& rear)
{vector<double> stk; // 操作数栈// 定义计算函数auto CalFunc = [](double a, double b, char op) -> double{if (op == '+')return a + b;else if (op == '-')return a - b;else if (op == '/')return a / b;else if (op == '*')return a * b;throw std::invalid_argument("error");};for (auto& ch : rear){if (isdigit(ch)) // 如果是数字,直接入栈{stk.push_back(ch - '0');}else // 如果是运算符,弹出两个操作数进行计算{double b = stk.back();stk.pop_back();double a = stk.back();stk.pop_back();double cal = CalFunc(a, b, ch);stk.push_back(cal);}// 输出当前状态cout << "current ch: " << ch << "\trearExp: \t" << rear << endl;printVec("STACK:", stk);}return stk.back(); // 栈顶元素即为最终结果
}int main()
{// 示例输入string mid;cout << "请输入中缀表达式(仅支持数字和 + - * / ( )): ";cin >> mid;// 中缀转后缀auto rear = MidToRear(mid);cout << "后缀表达式: " << rear << endl << endl;// 计算后缀表达式cout << "计算结果: " << CalRear(rear) << endl;return 0;
}

四、程序输出

以下是程序的运行输出示例,你可以根据实际输入填写输出结果。

输入示例:

9+8*(7-6)-5/4

输出示例:

 9+8*(7-6)-5/4
current ch: 9   rearExp:        9
STACK: |
current ch: +   rearExp:        9
STACK: | +
current ch: 8   rearExp:        98
STACK: | +
current ch: *   rearExp:        98
STACK: | +      *
current ch: (   rearExp:        98
STACK: | +      *       (
current ch: 7   rearExp:        987
STACK: | +      *       (
current ch: -   rearExp:        987
STACK: | +      *       (       -
current ch: 6   rearExp:        9876
STACK: | +      *       (       -
current ch: )   rearExp:        9876-
STACK: | +      *
current ch: -   rearExp:        9876-*+
STACK: | -
current ch: 5   rearExp:        9876-*+5
STACK: | -
current ch: /   rearExp:        9876-*+5
STACK: | -      /
current ch: 4   rearExp:        9876-*+54
STACK: | -      /
9876-*+54/-current ch: 9   rearExp:        9876-*+54/-
STACK: | 9
current ch: 8   rearExp:        9876-*+54/-
STACK: | 9      8
current ch: 7   rearExp:        9876-*+54/-
STACK: | 9      8       7
current ch: 6   rearExp:        9876-*+54/-
STACK: | 9      8       7       6
current ch: -   rearExp:        9876-*+54/-
STACK: | 9      8       1
current ch: *   rearExp:        9876-*+54/-
STACK: | 9      8
current ch: +   rearExp:        9876-*+54/-
STACK: | 17
current ch: 5   rearExp:        9876-*+54/-
STACK: | 17     5
current ch: 4   rearExp:        9876-*+54/-
STACK: | 17     5       4
current ch: /   rearExp:        9876-*+54/-
STACK: | 17     1.25
current ch: -   rearExp:        9876-*+54/-
STACK: | 15.75Cal ans:15.75
http://www.dtcms.com/a/578492.html

相关文章:

  • wangEditor在弹窗中的销毁注意事项,报错Error: Cannot resolve a Slate range from DOM rang
  • 防滑齿分布与牙钳防滑效能的关系
  • 商城网站网络公司wordpress主题 报纸
  • 站长工具seo诊断潍坊专业网站建设哪家便宜
  • 嵌入式Linux系统性能优化:深入剖析I/O性能瓶颈
  • 计算机操作系统:外存的组织方式
  • 【MCU控制 初级手札】1.7 离子、离子反应 【化学基础】
  • QML学习笔记(五十二)QML与C++交互:数据转换——时间和日期
  • 大模型agent技术
  • 松原市网站建设网站导航栏设计要求
  • 北京专业网站制作介绍大学生二手书网站开发需求
  • spark df 写入lanceDB
  • WebSocket 前端node启用ws调试
  • ArcGIS与ENVI在生态影响评价中的融合应用:八大专题图制作全解析
  • AI赋能企业办公:文多多AiPPT以技术创新破解行业痛点
  • 网站建设用哪的图片不侵权语言 网站开发
  • 网站建设公司的前景字体设计素材网
  • 嵌入式单片机各种通信(UART/RS232/RS485/I2C/CAN/ SPI)
  • 特斯拉股东大会前瞻,Optimus利好已至
  • 网站宣传的方法主要有2.0网站线上建设什么意思
  • iSCSI 磁盘扩容后节点不刷新容量的问题解决(StarWind + Linux)
  • Linux——web服务
  • 做淘宝客网站哪个好用wordpress文章图片保存到本地
  • 光子精密闪测仪 为中国制造提供更可靠、更高效、更懂工艺的尺寸测量方案
  • 上海设计师网站有哪些个人网站怎么设计
  • 【数据结构】非线性结构——树、堆,散列表和图
  • 怎样在百度上建网站南昌模板建站公司
  • 锐旗 天梯网站建设重庆seo网站系统
  • 学院校园网网站建设情况手机行业网站
  • 江苏恒健建设集团有限公司网站校车网站建设