原地交换两个变量的值
来源:互联网 发布:司考民法谁讲得好 知乎 编辑:程序博客网 时间:2024/06/06 06:37
第一种方法,大家会借助第三个变量来实现:
如: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和异或运算符合交换率。
异或的意思就是:不同 才可以得1,否则为0
// 异或
// 0^0=0
// 1^1=0
// 1^0=1
// 0^1=1
假如 a = 2,b = 4。想将a和b的值互换,可以用一下赋值语句实现: a = a ^ b; b = b ^ a; a = a ^ b;
此方法 完美,推荐使用。
0 0
- 原地交换两个变量的值
- 原地交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- 交换两个变量的值
- WebAPP(H5)与原生APP的交互设计区别
- 汉诺塔移动过程打印(Python & 递归)
- C# 调用C++ DLL 的类型转换(转载版)
- CSV文件及其使用
- 火星坐标和百度坐标之间的转换算法
- 原地交换两个变量的值
- 使用Freemarker宏进行可扩展式模块化编程
- 基于spring MVC 的验证码生成
- 怎么在一串长字符串中找出出现最多次数的字符?
- thinkphp 输出变量使用函数处理
- 思维工具:MindNode
- Android提醒技巧,Dialog、Toast和Snackbar的使用区别
- 文章标题:java基础课程学习日记(二)之日期问题
- uboot启动阶段修改启动参数方法及分析