C语言面试题---逻辑短路问题

作者: 安想创新教育 | 来源:发表于2017-12-22 13:06 被阅读11次

    版权声明:本文转载于公众号TeachPlus---C语言面试题---逻辑短路问题


    写出下面程序的输出

    #include  <stdio.h>

    int main()

    {

        int a=5,b=6,c=7,d=8,m=2,n=2;

        (m=ad);

        printf("%d\t%d",m,n);

        return 0;

    }

    本题答案

    答案为1,2

    本题解析

    本题的考察重点在于逻辑运算符的短路问题。

    在逻辑判断中,常常需要判断多个条件,如:

    if A and B;

    这时,当A为false时,无论B值是什什么,结果都为false,

    所以可以不用判断B,直接跳过。这种情况称为逻辑短路路。

    逻辑短路有许多应用,如

    if(name != NULL && name.equals("admin"))

    {

        //do somethings

    }

    这种情况下当name为null时,直接跳过判断name.equals("admin"),

    如果没有短路路效应,后面是有可能报空指针异常的。

    还有,满足某条件时执行函数

    f != null && ff();

    这样的语句,等价于

    if  (f != null)

    {

            f();

    }

    但是写法更更为简练。

    所以,对于本题来说,因为使用的是逻辑或运算符,

    因此只要两个条件中有一个为真,则整体为

    真,计算的时候先计算m=ad不予计算,故该程序的输出为1,2

    相关知识点

    如果对上面的程序作出如下修改:

    # include  <stdio.h>

    int  main()

    {

        int a=5,b=6,c=7,d=8,m=2,n=2;

        (m=a>b)&&(n=c>d);

        printf("%d\t%d",m,n);

    }

    则输出值为0,2

    该题的迷惑性更为大一点,程序首先计算m=a>b的值,

    因为a=4,b=6,所以a>b不成立,取值为0,

    即m=0,整体表达式为假。因为使用的是逻辑与运算符,

    必须两遍都为真,整体为真,所以当程序

    判断一个条件为假的时候,则进行短路路操作,

    第二个表达式不予就算,故该程序的整体输出为0,2.

    接下来可以看一道更更为巧妙的面试题,这是微软的一道题目:

    原题是:求 1 + 2 + 3 + … + n

    要求:

    不能用乘除法,不能用if if, while, do_while, for, switch, case,

    不能用(a < b ? a : b)三目运算符

    答案应为

    # include  <stdio.h>

    int  test( int n ,  int *sum)

    {

        n&& test(n-1,sum);

        return *sum += n;

    }

    int  main()

    {

        int ret = 0;

        test(100,&ret);

        printf("%d\n",ret);

        return 0;

    }

    如果没有那么多的限制的话,这是一道入门级的题目,但是正是因为有那么多的限制,

    所以这道题目才变得有意思起来,这道题目主要考察两个方面,

    一个是递归的使用,一个就是逻辑短路的使用了。

    递归的使用是显而易见的,不再赘述,而对于逻辑短路来说,

    用的就比较精妙了,大家可以看一下,作为参考。

    相关文章

      网友评论

        本文标题: C语言面试题---逻辑短路问题

        本文链接:https://www.haomeiwen.com/subject/pnbtgxtx.html