在C语言中,对于代码的分界采用的是贪心算法,也就是从按照从左到右可以组合的最大字符数来划分。
官方解释:每一个符号应该包含尽可能多的字符。也就是说,编译器将程序分解成符号的方法是,从左到右一个字符一个字符的读入,如果该字符可能组成一个符号,那么再读入下一个字符,判断已经读入的两个字符组成的字符串是否可能是一个符号的组成部分;如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串已不再可能组成一个有意义的符号。
比如上面这个题:a+++++b
从左到右开始,a可以和++组合,成为a++
之后再分解为++,从前面开始算就是(a++)++
之后为+b
也就是说按照贪心算法来算,a+++++b可以分解成:
((a++)++)+b
因为a++的结果为左值,而左值不能再进行运算,故a+++++b编译不能通过
除非写成a+++ ++b,在++b前面有个空格,这时候根据贪心算法分解为:
(a++)+(++b)
编译通过