Java里不用第三变量完成两个数字的交换

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;

                         同理完成数字交换。    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值