中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

逆波蘭表達式(后綴表達式)

發布時間:2020-07-21 09:09:57 來源:網絡 閱讀:1021 作者:朔月云影 欄目:編程語言

     逆波蘭表達式,它的語法規定,表達式必須以逆波蘭表達式的方式給出。逆波蘭表達式又叫做后綴表達式。下面是一些例子:

正常的表達式 逆波蘭表達式

a+b ---> a,b,+

a+(b-c) ---> a,b,c,-,+

a+(b-c)*d ---> a,b,c,-,d,*,+

a+d*(b-c)--->a,d,b,c,-,*,+

a=1+3 ---> a=1,3 +

   通過后綴表達式計算表達式值的過程:順序訪問表達式的每一項,若該項為操作數,則將其壓入棧中;若該項是操作符<op>,則連續從棧中退出兩個操作數X和Y,形成運算指令X<op>Y,將其結果重新壓入棧中。當表達式的每一項都訪問并處理,則其計算結果就是當前棧頂存放的值。

逆波蘭表達式(后綴表達式)

   下面我們以表達式4+3*4+3*(1+5)———>434*+315+*+

逆波蘭表達式(后綴表達式)

源程序:

#pragma once
#include<iostream>
#include<assert.h>
#include<stack>
using namespace std;

enum Type
{
    OP_NUM,
    OP_SYMBOL,
};

enum SYMBOL
{
    ADD,
    SUB,
    MUL,
    DIV,
};
struct Cell
{
    Type _type;
    int _value;
};
double CountRNP(Cell *a, size_t size)
{
    assert(a);
    stack<double> s;
    double right = 0;
    double left = 0;
    for (size_t i = 0; i < size; i++)
    {
        if (a[i]._type == OP_NUM)
        {
            s.push(a[i]._value);
        }
        else
        {
            if (s.empty())
            {
            return 0;
            }
            right = s.top();
            if (s.empty())
            {
            return 0;
            }
            s.pop();
            left = s.top();
            s.pop();
            switch (a[i]._value)
            {
            case ADD:
                s.push(left + right);
                break;
            case SUB:
                s.push(left - right);
                break;
            case MUL:
                s.push(left * right);
                break;
            case DIV:
                if (left== 0)
                    {
                        cout << "error" << endl;
                    }
                else
                    {
                       s.push(right / left);
                    }    
                break;
            }
        }
    }
    return s.top();
}

測試代碼:

#include"calculate.h"
int main()
{
    Cell a[] = { { OP_NUM, 4 }, { OP_NUM, 3 }, { OP_NUM, 4 },
    { OP_SYMBOL, MUL }, { OP_SYMBOL, ADD }, { OP_NUM, 3 }, { OP_NUM, 1 }
    , { OP_NUM, 5 }, { OP_SYMBOL, ADD }, { OP_SYMBOL, MUL }, { OP_SYMBOL, ADD } };
    size_t size = sizeof(a) / sizeof(a[0]);
    cout << CountRNP(a, size) << endl;
    system("pause");
    return 0;
}

結果:

逆波蘭表達式(后綴表達式)

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岳阳市| 阿鲁科尔沁旗| 金川县| 桂平市| 平远县| 聂荣县| 新源县| 镇远县| 蓝山县| 哈尔滨市| 灵丘县| 黄龙县| 怀宁县| 车险| 乐安县| 怀仁县| 团风县| 杂多县| 闵行区| 荥阳市| 宜宾县| 吉安市| 永兴县| 十堰市| 五华县| 麻城市| 洛浦县| 庆城县| 精河县| 安平县| 宜兰市| 岑巩县| 屏山县| 宁乡县| 吉林省| 布尔津县| 石泉县| 新泰市| 尉氏县| 英吉沙县| 鹤山市|