Java交换两变量值(三种方法)

本文介绍了交换两个数字值的三种方法:中间变量法、加减运算法和异或运算法。中间变量法是最常见的,适用于所有类型的数据;加减运算法依赖于数字且存在溢出风险;异或运算法则适用于整数,利用了异或运算的性质实现无额外空间的交换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 中间变量(最普遍、最广泛使用的交换方式)

在这里插入图片描述

这种方法很容易理解,就是创建temp中间变量,m把值给temp,n给m,temp将m的值给n,这样就实现了交换。

2. 加减运算(前提只能是数字,但如果两数本来就过大,两数相加时会有溢出风险)

在这里插入图片描述

因为这种方法需要运算,所有只能是数字,eg:m=8,n=2;第一步求出两数的和为10,传给m,再用总数减去n就是原来m的值,传给n,然后总数再减去原来m的值,得到原来n的值,传给m,实现交换。

3. 异或运算(前提只能是整数)

在这里插入图片描述

这种方法不常见到(但很重要、很猥琐、很魔幻,需铭记,是由于异或运算的强大,建议不太熟悉概念和特性的一定要去补补),这要先把数字转换成二进制
例如:m = 3 = 0011,n=4 = 0100

第一步:m^n异或结果:0011 ^ 0100 = 0111 = 7,赋给m

第二步:m^n异或结果:0111 ^ 0100 = 0011 = 3,赋给n

第三步:m^n异或结果:0111 ^ 0011 = 0100 = 4,赋给m

实现了 m n 交换

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术园地

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值