[算法]不用第三个数交换2个数的位置

Posted WE丶301

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[算法]不用第三个数交换2个数的位置相关的知识,希望对你有一定的参考价值。

int a = 10;

int b = 20;

 

第一种方法:

a = a + b;

b = a - b;

a = a - b;

 

第二种方法:

a = a ^ b; (^   语言中是异或的意思,同为0 异为1  1 ^ 1 = 0, 0 ^ 0 = 0, 1 ^ 0 = 1)

b = a ^ b;

a = a ^ b;

 

第三种方法  (这种方法容易越界)如果a 大于int型最大值了!

a = (a + b) - (b = a);

以上是关于[算法]不用第三个数交换2个数的位置的主要内容,如果未能解决你的问题,请参考以下文章

冒泡排序

排序系列 之 简单选择排序及其改进算法 —— Java实现

python 冒泡排序

算法基础--简单选择排序

插入排序

交换排序-冒泡排序 + 普通交换排序