Java里不用第三变量完成两个数字的交换
2013-10-12 21:35
337 查看
import java.util.Scanner;
public class Demo11 {
public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
int num1 =scan.nextInt();
int num2=scan.nextInt();
System.out.println("交换前:num1="+num1+",num2="+num2);
num1=num1^num2;
num2=num1^num2;(等价于num2=(num1^num2)^num2=num1)即把num1的值赋给了num2
num1=num1^num2;(等价于num1=(num1^num2)^(num1^num2)^num2)=num2),即把num2的值给了num1,因此完成数据交换
System.out.println("交换后:num1="+num1+",num2="+num2);
}
}
代码如上:没有第三变量二完成了两个整型变量的交换,这种交换方式通过“异或”来实现的。那么这个过程是什么样子呢?
首先我们要清楚“异或”运算的运算规则:1 ^ 1=0 1 ^ 0=1 0 ^ 1=1 0 ^ 0=0
定理一a ^ b = b ^ a
定理二 a ^ b ^ c = a ^ (b ^ c) = (a ^ b) ^ c;
定理三 a ^ b ^ a = b, a ^ a^ b = b, b ^ a^ a = b
如 我们输入:num1=2=0010(二进制), num2=3=0011,则num1^num2=2^3=0010^0011=0001=1,即把1赋值给了num1,则第一个式子等价于num1=1;
同理完成数字交换。
public class Demo11 {
public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
int num1 =scan.nextInt();
int num2=scan.nextInt();
System.out.println("交换前:num1="+num1+",num2="+num2);
num1=num1^num2;
num2=num1^num2;(等价于num2=(num1^num2)^num2=num1)即把num1的值赋给了num2
num1=num1^num2;(等价于num1=(num1^num2)^(num1^num2)^num2)=num2),即把num2的值给了num1,因此完成数据交换
System.out.println("交换后:num1="+num1+",num2="+num2);
}
}
代码如上:没有第三变量二完成了两个整型变量的交换,这种交换方式通过“异或”来实现的。那么这个过程是什么样子呢?
首先我们要清楚“异或”运算的运算规则:1 ^ 1=0 1 ^ 0=1 0 ^ 1=1 0 ^ 0=0
定理一a ^ b = b ^ a
定理二 a ^ b ^ c = a ^ (b ^ c) = (a ^ b) ^ c;
定理三 a ^ b ^ a = b, a ^ a^ b = b, b ^ a^ a = b
如 我们输入:num1=2=0010(二进制), num2=3=0011,则num1^num2=2^3=0010^0011=0001=1,即把1赋值给了num1,则第一个式子等价于num1=1;
同理完成数字交换。
相关文章推荐
- java中不用第三变量交换两个变量的值
- ADO.NET面试题之基础篇不用第三变量交换两个变量的值
- 交换两个变量而不用第三变量
- 剑指Offer(Java版):不用第三个变量就能交换两个变量值
- 不用第三变量交换两个整数
- [Java,JS] - 不使用第三个变量完成两个整数的交换
- 不用引入第三变量交换两个变量的值
- 一面试题:不用任何中间变量,完成两个int型的交换。
- java中不用第三个变量交换两个变量的值
- [2016/12/5]不用第三个变量交换两个数字
- 不用设置第三变量,交换两个变量
- [JAVA] 一条新闻引出的思考,关于不用中间变量交换两个变量的值
- 不用引入第三变量交换两个变量的值
- 两个变量交换数字 不用第三个变量的情况下 int a = 5,b = 6
- 由“不用第三个变量,直接交换两个…
- 不用中间变量,交换两个变量时,要注意!!!
- java(引入一个中间变量,不引入中间变量)交换两个变量的值
- Java实现两个整数变量的交换
- JAVA和C++ 交换两个变量的值的函数 区别
- 【转】 不用中间变量,实现两个变量的交换