中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式

直接上代碼

public static class InfixToPostfix
{
    private static List<char> highOperator = new List<char> { '*', '/' };
    private static List<char> lowOperator = new List<char> { '+', '-' };

    public static string Method(string str)
    {
        var stack = new Stack<char>();
        var ans = new StringBuilder();
        foreach (char item in str)
        {
            if (item >= 48 && item <= 57)
            {
                ans.Append(item);
            }
            else if (item == '(')
            {
                stack.Push(item);
            }
            else if (item == ')')
            {
                while (stack.Count > 0)
                {
                    var preOpe = stack.Pop();
                    if (preOpe == '(')
                    {
                        break;
                    }
                    ans.Append(preOpe);
                }
            }
            else // 操作符
            {
                if (stack.Count != 0)
                {
                    var preOpe = stack.Peek();
                    // 棧頂操作符優(yōu)先級大于等于當(dāng)前操作符優(yōu)先級
                    if ((highOperator.Contains(preOpe) && highOperator.Contains(item))
                        || (highOperator.Contains(preOpe) && lowOperator.Contains(item)))
                    {
                        ans.Append(stack.Pop());
                    }
                }

                stack.Push(item);
            }
        }

        while (stack.Count > 0)
        {
            ans.Append(stack.Pop());
        }

        return ans.ToString();
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容