中缀表达式转后缀表达式

直接上代码

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();
                    // 栈顶操作符优先级大于等于当前操作符优先级
                    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();
    }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容