美文网首页
交换两个数

交换两个数

作者: hainingwyx | 来源:发表于2017-07-24 16:09 被阅读20次

    你看到的这个文章来自于http://www.cnblogs.com/ayanmw/p/3423712.html

    • 第一种方法,大家会借助第三个变量来实现:

    如:

    tmp=A;
    A=B;
    B=tmp;
    

    这种方法需要借助第三变量来实现;

    • 第二种方法是利用加减法实现两个变量的交换,
    A=A+B;
    B=A-B;
    A=A-B;
    

    但是 如果 A+B 超出 A的返回 ,就会出错!极为不推荐 此方法

    • 第三种方法是得用位异或运算来实现,也是效率最高的一种,在大量数据交换的时候,效率明显优于前两种方法,
    A=A^B;
    B=A^B;
    A=A^B;
    

    原理:利用一个数异或本身等于0和异或运算符合交换率。
    此方法完美,推荐使用。

    相关文章

      网友评论

          本文标题:交换两个数

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