两个数的交换方法(三种解决方案)

两个数交换的解决方案(3种)

前提: i^i=0 j^0=j abb=a
int x = 1,y = 2; x = 2 ,y= 1;

//两个数交换的解决方案(3种)
		//进行三次按位异或,得到数据的交换
		int k=2,l=1;
		k=k^l;
		l=k^l;   //l=k^l^l,所以l=k
		k=k^l;   //k=k^l^k,所以k=l
		System.out.println("第一种:"+k+","+l);
		//取一个中间值,让两个数字进行数据的交换
		k=2;l=1;
		int temp;
		temp=k;
		k=l;
		l=temp;
		System.out.println("第二种:"+k+","+l);
		//进行数据的相加减,得到数据最终的互换,不适合用于小数的交换
		k=2;l=1;
		k=k+l;
		l=k-l;
		k=k-l;
		System.out.println("第三种:"+k+","+l);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值