• C++短路求值(逻辑与、逻辑或)


    1逻辑或的短路

    首先看如下代码:

    #include <iostream>
    using namespace std;
    int main()
    {
      int a = 1;
      cout << "a = " << a <<endl;
      true || (a=0);
      cout << "a = " << a <<endl;
    }

    运行结果:

    a = 1

    a = 1

    逻辑或的表现形式如下:

    expression1 || exexpression2

    这里用到了逻辑或,由于逻辑或的短路,expression1true,则后面的expression2(即:(a=0) )不再求值,整个表达式的结果为true,所以a的值仍为1,没有改变。

    2逻辑与的短路

    首先看如下代码:

    #include <iostream>
    using namespace std;
    int main()
    {
        int a = 1;
        cout << "a = " << a <<endl;
        false && (a=3);
        cout << "a = " << a <<endl;
    }

    运行结果:

    a=1

    a=1

    逻辑与的表现形式如下:

    expression1 && exexpression2

    上述代码中用到了逻辑与,由于逻辑与的短路,expression1false,则后面的expression2不再求值,整个的结果为false,所以a的值没有改变。

    3、应用举例

    这里以CSDN上的一个帖子为例(http://topic.csdn.net/u/20121011/10/c7e0a805-b4e2-44db-9d71-455f5f851240.html ):

    不用if语句,不用汇编,怎么使得两数之积总是小于等于255?

    大家看过帖子会发现有很多方法,比如最简单的条件表达式:

    result = ((a*b) > 255) ? 255 : a*b;

    这个是最先被人提出的,但好像楼主不认同,那就试下以下两种方式:

    逻辑或的短路

    bool tmp = ((result = a*b) < 255) || (result=255);

    逻辑与的短路:

    bool tmp = ((result = a*b) >= 255) && (result=255);

    完整代码: 

    View Code
    #include <iostream>
    using namespace std;
    int main()
    {
        int a,b,result;
        while (true)
        {
            cin>>a>>b;
    //       result = ((a*b) > 255) ? 255 : a*b;
    //       bool tmp = ((result = a*b) < 255) || (result=255);
            bool tmp = ((result = a*b) >= 255) && (result=255);
            cout<<result<<endl;
        }
    }

    运行效果如下: 

    个人拙见,不足之处欢迎指出。

    好,就这些了,希望对你有帮助。

  • E-Mail : Mike_Zhang@live.com
  • 转载请注明出处,谢谢!
  • 相关阅读:
    基础数论--例题
    基础数论--扩展欧几里得算法
    基础数论--欧拉定理,逆元
    基础数论--快速幂
    基础数论--欧拉函数
    基础数论--约数
    数论基础--质数
    图算法--二分图的最大匹配(匈牙利算法)
    WEB/APP开发基础之旅--网页布局
    WEB/APP开发基础之旅--HTML入门2
  • 原文地址:https://www.cnblogs.com/MikeZhang/p/cppAndOrTest20121020.html
  • Copyright © 2020-2023  润新知