面试题中自增自减类型题目的解题技巧


    在面试中,我们经常被问有关于自增自减的题目,这样的题目简单易懂,便于检验面试者的编程基本功,楼主在百度实习面试中就被问到。现在总结一下解题技巧:


    对于以下,有int x = 5, y = 6, z;

    题目1:z = ++x + y++;

    题目2:z = ++x + x++;

    题目3:x = ++x + x++;


    对于上面的三道题目,我们下面一一解答。使用的技巧就是:把原始计算式转化成多个、有先后计算顺序的、小的计算式,然后带入变量的值,进行求解。记住:同一优先级的运算符的计算顺序是从右往左。

    Q1:z = ++x + y++;  可以转化为:

                  x = x +1;

                  z = x + y;

                  y = y + 1;

    带入x = 5, y = 6,可得x = 6; z = 12; y = 7; 


    Q2:z = ++x + x++;  可以转化为:

                  x = x +1;

                  z = x + x;

                  x = x + 1;

    带入x = 5,可得x = 6; z = 6+6=12; x = 7;   故x=7,z=12;


    Q3:x = ++x + x++;  可以转化为:

                  x = x +1;

                  x = x + x;

                  x = x + 1;

    带入x = 5,可得x = 5+1=6; x = 6+6=12; x = 12+1=13;   故x=13。


    注意:一定要等把原始公式全部转换成小公式之后,再带入变量值,切不可中途带入变量值!


    Q4:z = x > y ? ++x : y++; 

    条件运算符有短路的原则,由于x>y是假的,所以冒号前面的++x是不运行的,即使它是前++,我们直接运行y++,但是y是后++,所以z = 6, y = y+1=7.




猜你喜欢

转载自blog.csdn.net/puqutogether/article/details/45823591