算法--实现两个数互换(不引入第三方变量)
2016-04-09 17:26
225 查看
m = 3
n = 8
现在是想m与n互换;
1、我们一般想到的就是引入第三方变量。
temp = m;
m = n;
n =temp;
这是比较常见的,但是现在我们不希望引入第三方变量,怎么做呢?
2、 int m = 8, n=3;
n = n+m = 11
m = n - m = 3;
n = n-m = 8;
但是这种方法又局限性,当n和m的值非常大,那就容易超出了int的范围;
3、n = n^m;
m = n^m; ========> (n^m)^m=n;
n = n^m; ========> (m^n)^n=m;
n异或一个数两次还是n本身;
开发的时候推荐使用第一种,因为容易想到。
n = 8
现在是想m与n互换;
1、我们一般想到的就是引入第三方变量。
temp = m;
m = n;
n =temp;
这是比较常见的,但是现在我们不希望引入第三方变量,怎么做呢?
2、 int m = 8, n=3;
n = n+m = 11
m = n - m = 3;
n = n-m = 8;
但是这种方法又局限性,当n和m的值非常大,那就容易超出了int的范围;
3、n = n^m;
m = n^m; ========> (n^m)^m=n;
n = n^m; ========> (m^n)^n=m;
n异或一个数两次还是n本身;
开发的时候推荐使用第一种,因为容易想到。
相关文章推荐
- 山东省第四届ACM大学生程序设计竞赛-Rescue The Princess(计算几何)
- Servlet监听器示例
- 1——A Journey into Microservices
- adb devices指令实例讲解
- Spring学习之代理
- framework4.0 IIS配置支持ashx
- SparseLM Demo示例分析
- HTML中div垂直居中的三种方式
- AVAudioPlayer与AVPlayer播放音频
- SQL优化技巧(Oracle)
- 旅游
- iOS获取相册/相机图片-------自定义获取图片小控件
- a 标签中调用js的几种方法
- Nginx+tomcat负载均衡配置
- TSM 报服务器空间不足 磁带都标记为BAD TYPE
- LeetCode *** 225. Implement Stack using Queues
- OpenGL基础图形编程(六)OpenGL辅组库的基本使用
- 朴素求欧拉函数模板(1787)
- 关于[[NSBundle mainBundle] infoDictionary]里面的那些东西
- 实用站点收集