使用修改的反向波兰符号求解方程
Solving equations with modified Reverse Polish Notation
我必须编写一个程序,用四个基本运算来求解方程。程序必须看起来像:
示例输入:
SET a = 1
SET b = 3
SOLVEFOR c ( 4 * ( b - c + 2) + a ) = ( 2 - a )
输出:
c = 5.000000
我使用反向波兰符号来评估方程右侧的值(我知道那里只有已知的数字)。至于左边,那是我的问题。我知道必须有一种方法来修改RPN以获得该变量,但我不知道应该如何完成。有什么建议吗?
编辑:我知道这可以用二叉树完成,但我正在尝试使用RPN。
如果可以用二叉树求解,那么就可以用RPN求解。
首先在纸上用二叉树画出你的解决方案。当你能看到的时候,思考会更容易。您将在不影响方程式结果的情况下对树进行再平衡操作。
一旦将未知隔离在左手边,你就完了。每个再平衡操作在RPN中都有一个等价的操作(它是树的平面表示)。
当你看到你绘制的解决方案时,洞察力就会到来。
相关文章:
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 将无符号char*转换为std::istream*C++
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- vscode g++链路故障:体系结构x86_64的未定义符号
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- 使用gcc从静态链接的文件中查找可选符号
- C++中无符号字符溢出
- 使用无符号字符数组有效存储内存
- C++:Application.cpp中抛出了未解析的外部符号(解决方案在问题的末尾,供未来的读者参考)
- VC++本机单元测试,找不到调试符号
- 为什么我必须在C++中添加一个赋值符号来声明一个数组
- 检查TCHAR数组输入是否为带符号整数C++
- 用符号版本替换对函数的所有调用
- 未解析的外部符号_MsiLocateComponentW@12.
- 正弦级数方程计算不正确
- 求解后缀符号方程c++
- 使用修改的反向波兰符号求解方程