如何以编程方式将表达式括起来?

Jer*_*ten 3 algorithm parsing operator-precedence parentheses

我对一个简单的程序有一个想法,这将帮助我在C语言中使用运算符优先级.最困难的部分是括号表达式.例如,我想要这个:

*a.x++ = *b.x++
Run Code Online (Sandbox Code Playgroud)

转换为:

((*(((a).(x))++)) = (*(((b).(x))++)))
Run Code Online (Sandbox Code Playgroud)

我在这些步骤中手动完成的操作:

           *a.x++ = *b.x++
       *(a).(x)++ = *(b).(x)++
     *((a).(x))++ = *((b).(x))++
   *(((a).(x))++) = *(((b).(x))++)
 (*(((a).(x))++)) = (*(((b).(x))++))
((*(((a).(x))++)) = (*(((b).(x))++)))
Run Code Online (Sandbox Code Playgroud)

以编程方式完成此操作的最佳方法是什么?我可以使用的解决方案吗?我更喜欢用PHP,C,C++,Python或Ruby来做这件事.

(这不是我的计划的全部想法,它只是第一步.)

Cha*_*tin 6

您将需要某种能够理解运算符优先级的解析器.C的常用版本是Lexx/Yacc或flex/bison,最简单的方法是构造一个解析树.完成后,只需按照"预订"顺序浏览解析树,并在进入和离开节点时发出parens.