【问题标题】:Converting string expression to boolean logic - C#将字符串表达式转换为布尔逻辑 - C#
【发布时间】:2016-08-24 02:57:40
【问题描述】:

我想将字符串表达式转换为真正的布尔表达式。

下面的表达式将是一个输入(字符串):

"(!A && B && C) || (A && !B && C) || (A && B && !C) || (A && B && C)"

变量 A、B 和 C 将具有您的布尔值(真或假)。

如何转换字符串表达式、替换逻辑值并使用 C# 进行验证?

【问题讨论】:

标签: c# logic expression


【解决方案1】:

如果您不想使用一些可用的库来解析该字符串,您需要分离这些字符并实现基于比较的逻辑。例如,假设我们有"a || b",我们可以遍历每个字符并根据char == '|' 决定适当的操作。对于更复杂的情况,我会使用stack 来跟踪每个结果,例如可以处理&&|| 且不带括号:

public bool ConvertToBool(string op, bool a, bool b)
{
    var st = new Stack<bool>();
    var opArray = op.ToCharArray();
    var orFlag = false;
    var andFlag = false;

    for (var i = 0; i < opArray.Length; i++)
    {
        bool top;
        switch (opArray[i])
        {
            case '|':
                i++;
                orFlag = true;
                break;
            case '&':
                i++;
                andFlag = true;
                break;
            case 'a':
                if (orFlag)
                {
                    top = st.Pop();
                    st.Push(top || a);
                    orFlag = false;
                }
                else if (andFlag)
                {
                    top = st.Pop();
                    st.Push(top && a);
                    andFlag = false;
                    continue;
                }
                st.Push(a);
                break;
            case 'b':
                if (orFlag)
                {
                    top = st.Pop();
                    st.Push(top && b);
                    orFlag = false;
                }
                else if (andFlag)
                {
                    top = st.Pop();
                    st.Push(top && b);
                    andFlag = false;
                    continue;
                }
                st.Push(b);
                break;
        }
    }
    return st.Pop();
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多