91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

QT之計算器核心解析算法(十)

發布時間:2020-07-16 04:09:42 來源:網絡 閱讀:1107 作者:上帝之子521 欄目:開發技術
    上節我們說到計算機默認的是后綴表達式,那么中綴表達式轉后綴表達式的過程就類似于編譯過程。

必須得注意這么幾個問題:四則運算表達式中的括號必須匹配;根據運算符優先級進行轉換;轉換后的表達式中沒有括號;轉換后可以順序計算出最終結果。
下來我們就講下具體的轉換過程:
1、當前元素 e 為數字:輸出
2、當前元素 e 為運算符時:1. 與棧頂運算符進行優先級比較;2.小于等于時將棧頂元素輸出,轉1;3.大于時將當前元素 e 入棧
3、當前元素 e 為左括號:入棧
4、當前元素 e 為右括號:1.彈出棧頂元素并輸出,直至棧頂元素為左括號;2.將棧頂的左括號從棧中彈出
用偽代碼描述出來就是這樣:
QT之計算器核心解析算法(十)
其中的關鍵點是轉換過程中左右括號是重要的標志,那么如何確保表達式中的括號能夠左右匹配?
那么在合法的四則運算表達式中:括號必然是成對出現的,左括號必然先于右括號出現,可以用偽代碼進行描述:
QT之計算器核心解析算法(十)
經過這樣,我們就可以確保計算機正確的將中綴表達式轉換成后綴表達式,也就是將表達式轉換為計算機理解的行為。
那么這是計算機所轉換的三個示例:
QT之計算器核心解析算法(十)
下來我們構建運行下程序看看輸出是否正確執行,我們在構造函數這樣輸入:
QT之計算器核心解析算法(十)
輸出結果如下:
QT之計算器核心解析算法(十)
匹配函數的具體代碼如下:
bool QCalculatorDec::match(QQueue<QString>& exp)
{
bool ret = true;
int len = exp.length();
QStack<QString> stack;

                for(int i=0; i<len; i++)
                {
                        if( isLeft(exp[i]) )
                        {
                                stack.push(exp[i]);
                        }
                        else if( isRight(exp[i]) )
                        {
                                if( !stack.isEmpty() && isLeft(stack.top()) )
                                {
                                        stack.pop();
                                }
                                else
                                {
                                        ret = false;
                                        break;
                                }
                        }
                }

                return ret && stack.isEmpty();
        }

     轉換函數的具體代碼如下:
     bool QCalculatorDec::transform(QQueue<QString>& exp, QQueue<QString>& output)
    {
            bool ret = match(exp);
            QStack<QString> stack;

            output.clear();

            while( ret && !exp.isEmpty() )
            {
                    QString e = exp.dequeue();

                    if( isNumber(e) )
                    {
                            output.enqueue(e);
                    }
                    else if ( isOperator(e) )
                    {
                            while( !stack.isEmpty() && (priority(e) <= priority(stack.top())) )
                            {
                                    output.enqueue(stack.pop());
                            }

                            stack.push(e);
                    }
                    else if( isLeft(e) )
                    {
                            stack.push(e);
                    }
                    else if( isRight(e) )
                    {
                            while( !stack.isEmpty() && !isLeft(stack.top()) )
                            {
                                    output.enqueue(stack.pop());
                            }

                            if( !stack.isEmpty() )
                            {
                                    stack.pop();
                            }
                    }
                    else
                    {
                            ret = false;
                    }
            }

            while( !stack.isEmpty() )
            {
                    output.enqueue(stack.pop());
            }

            if( !ret )
            {
                    output.clear();
            }

            return ret;
    }

那么今天的學習就到這了,現在程序已經能按照計算機的思維進行四則運算的讀取了,后面我們繼續學習相關知識。

向AI問一下細節

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

AI

吐鲁番市| 望谟县| 晋州市| 萍乡市| 信阳市| 安丘市| 温州市| 会东县| 孝义市| 弋阳县| 昆山市| 无棣县| 南川市| 石柱| 淮滨县| 财经| 临海市| 莒南县| 兴文县| 浏阳市| 东明县| 东莞市| 西城区| 海盐县| 德化县| 林周县| 乐昌市| 班戈县| 高台县| 松阳县| 九龙城区| 福清市| 白银市| 平昌县| 新巴尔虎左旗| 阿拉善右旗| 治多县| 松江区| 察哈| 三明市| 凤凰县|