c # Algoritmo polaco inverso para analizar cadenas

Algoritmo polaco inverso para analizar cadenas

Referencia: https://www.cnblogs.com/lxfqlcz/archive/2011/08/02/2124854.html

Se ha realizado una ligera mejora en el artículo anterior para admitir la lógica, como los cálculos de funciones trigonométricas y resolver problemas que entran en conflicto con los operadores.

El código mejorado es el siguiente:

 List<string> m_funOperators = new List<string>() { "tan", "sin", "cos", "cot", "sec", "csc", "log", "loge", "ln", "abs" };

//exp=A*1.0#+SIN(B*1.2)-COS(C)+3/2-TAN(45)/(1+F)+LOG(G)-1.5*D+ln8
 public bool Parse(string exp)
{
     exp = exp.ToUpper();
     string pattern = @"\b(" + string.Join<string>("|", m_funOperators).ToUpper() + ")" + @"\b";
    exp = Regex.Replace(exp, pattern, new MatchEvaluator((m) =>
     {
         return m.Value.ToLower();
     }));
    m_tokens.Clear();
   .......
}

referencia:

https://www.codeproject.com/Articles/34626/C-RPN-Expression

https://mp.weixin.qq.com/s/Zdof-uGtQ0CylF544ZYbUA

 

 

Supongo que te gusta

Origin blog.csdn.net/fuweiping/article/details/114844210
Recomendado
Clasificación