广告
返回顶部
首页 > 资讯 > 精选 >Java不使用第三方变量交换两个变量值的方法有哪些
  • 769
分享到

Java不使用第三方变量交换两个变量值的方法有哪些

2023-06-22 00:06:37 769人浏览 八月长安
摘要

本篇内容介绍了“Java不使用第三方变量交换两个变量值的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题:请说出几种不使用第三方

本篇内容介绍了“Java不使用第三方变量交换两个变量值的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

问题:请说出几种不使用第三方变量交换两个变量值的方法。

遇到交换变量值的问题,通常我们的做法是:定义一个新的变量,借助它完成交换。

代码如下:

t = a;a = b; b = t;

但问题的重点是“不使用第三方变量”,那就变得“可爱”起来了。思考过后,抛出以下四种方法来解决该问题:

  • 变量本身交换数值;

  • 算术运算;

  • 指针地址操作;

  • 位运算;

变量本身交换数值

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

首先执行 a + b 操作,然后将 b 赋值给 a,则 b = a + b - b = a,这就完成了 ab 的互换操作。

算术运算

Java不使用第三方变量交换两个变量值的方法有哪些

如图所示:

OA = a;

OB = b;

AB = b - a;

首先我们把 AB 之间的距离 b - a 赋值给 a,此时 AB = a, OB = b 。

Java不使用第三方变量交换两个变量值的方法有哪些

由于要达到 ab 交换的目的,所以 OA 要等于 b,而此时 OA 的距离为 b - a ,所以得将 b - a 赋值给 b ,此时 OA = b, AB = a 。

Java不使用第三方变量交换两个变量值的方法有哪些

很容易从图中看出,OB 的距离为 b + a,所以我们只需要将 b + a 赋值给 a 就可以完成两者的交换了。

Java不使用第三方变量交换两个变量值的方法有哪些

综上所述,我们的步骤为

int a = 10;int b = 15;a = b - a; //b=15;a=5;b = b - a; //b=10;a=5;a = b + a; //b=10;a=15;

算法只能用于整型类型。

指针地址操作

Java不使用第三方变量交换两个变量值的方法有哪些

我们可以把 a 和 b 想象为内存中的地址值,假设 a 为 0x01ff5e70 ,b 为 0x01ff5e90 ,而 b - a 表示两个变量在内存中的储存位置隔了多少个字节。所以我们理论上也可以按算术运算的逻辑来交换两个变量的值。

代码如下(此处是 c 语言):

//其中 a 和 b 都是指针变量,里边存储着10和20的地址int *a = new int(10); //a=0x01ff5e70 ,此处代表a中存储的地址int *b = new int(20); //b=0x01ff5e90 ,此处代表b中存储的地址//指针变量相减得到20和10的地址间隔了多少个字节,然后转为指针变量a = (int*)(b-a); //b=0x01ff5e90;a=0x8b = (int*)(b-a); //b=0x01ff5e70;a=0x8a=(int*)(b+long(a));//b=0x01ff5e70;a=0x01ff5e90

b - a = 0x01ff5e90 - 0x01ff5e70 = 0x20,0x20 转换为十进制为 32 位,因为一个 int 占4位,所以这里是 0x8 。

以上只是理论状态下的执行过程,如果直接执行是不能实现交换的。因为上边的代码忽略了一个问题:代码编译之后,变量都是存在内存中的,而内存区都会存在基地址。

基地址可以理解为某块内存的起点。上边的数据都是在基地址的基础上做了偏移。

变量的地址 = 变量的基地址 + 变量的偏移地址

当我们进行 b - a 操作的时候,得到结果为 8 ,然后转化为指针变量的时候就会给 8 自动添加基地址,此时的结果就不是 0x8 了,所以会导致结果错误。

另外,地址运算不能出现负数,即当 a 的地址大于 b 的地址时,b - a < 0 ,系统自动采用补码的形式表示负的位移,也会产生错误。

为了解决这个问题,我们只需要保证 b - a 得到的结果不受基地址的影响即可,所以给出以下解决方案。

int *a = new int(10);int *b = new int(20); cout << a << "`````";cout << b << "`````";if(a < b){a = (int*)(b-a); cout << a << "`````";b=(int*)(b-(long(a)&0x0000ffff));cout << b << "`````";a=(int*)(b+long(a));cout << a << "`````";} else {b = (int*)(a-b); cout << b << "`````";a=(int*)(a-(long(b)&0x0000ffff));cout << a << "`````";b=(int*)(a+long(b));cout << b << "`````";}

执行结果:

0x8dbe70`````0x8dbe90`````0x8`````0x8dbe70`````0x8dbe90`````

看到这,不知道大家是否真的看懂了。反正我第一次看到这儿时,感觉非常清晰(其实完全没有理解),第二次看的时候懵逼了,完全不懂,所以还得大家仔细思考一下才行。

b=(int*)(b-(long(a)&0x0000ffff)); 指令的精妙之处就在于采用了位运算中的与运算,将 a 和 0x0000ffff 进行与运算后,b - a 的基地址计算结果被屏蔽,只保留了偏移地址的计算结果,也就是我们需要的字节数。

在交换很大的数据类型时,该方法执行速度比算术算法快。因为它交换的是地址,而变量值在内存中是没有移动过的。

位运算

既然上边用到了位运算,那我们再说一种直接通过“异或“完成交换的方法。

简单介绍一下异或的规则:

  • 如果a、b两个值不相同,则异或结果为1;

  • 如果a、b两个值相同,异或结果为0。

代码如下

int a=10, b=12;//二进制:a=1010;b=1100;a = a^b;//a=0110;b=1100b = a^b;//a=0110;b=1010a = a^b;//a=1100;b=1010System.out.println("a="+ a +",b="+ b);

执行结果

a=12,b=10

异或运算能够使数据中的某些位翻转,其他位不变。这就意味着任意一个数与任意一个给定的值连续异或两次,值不变。

“Java不使用第三方变量交换两个变量值的方法有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java不使用第三方变量交换两个变量值的方法有哪些

本文链接: https://www.lsjlt.com/news/301654.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java不使用第三方变量交换两个变量值的方法有哪些
    本篇内容介绍了“Java不使用第三方变量交换两个变量值的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题:请说出几种不使用第三方...
    99+
    2023-06-22
  • Java不使用第三方变量交换两个变量值的四种方法详解
    目录变量本身交换数值算术运算指针地址操作位运算简单总结哈喽,大家好,我是阿Q。前几天有个小伙伴去面试,被面试官的一个问题劝退了:请说出几种不使用第三方变量交换两个变量值的方法。 问题...
    99+
    2022-11-12
  • php怎么不用第三个变量交换两个变量的值
    本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑php不用第三个变量交换两个变量的值方法1:使用异或运算<php header("Content-type:text/html;charset=utf-...
    99+
    2019-02-25
    php 交换变量值
  • Java中不用第三个变量来互换两个变量的值
    我们先看看使用第三变量的方法。(开胃菜) class Swap{ public static void main(String[] args){ int ...
    99+
    2022-11-12
  • PHP实现交换两个整型变量的方法有哪些
    这篇文章主要介绍“PHP实现交换两个整型变量的方法有哪些”,在日常操作中,相信很多人在PHP实现交换两个整型变量的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP实现交换两个整型变量的方法有哪些...
    99+
    2023-06-25
  • C#交换两个变量值的几种方法总结
    在学习.Net/C#或者任何一门面向对象语言的初期,大家都写过交换两个变量值,通常是通过临时变量来实现。本篇使用多种方式实现两个变量值的交换。 假设int x =1; int y =...
    99+
    2022-11-13
    C# 交换两个变量值 交换变量值
  • java如何在不用第三个变量的情况下交换两个字符串
    这篇文章给大家分享的是有关java如何在不用第三个变量的情况下交换两个字符串的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。如何在不用第三个变量的情况下交换两个字符串这道题就有点意思了,对吧尤其是前提条件,不使用第...
    99+
    2023-06-27
  • C语言不使用临时变量怎么交换两个整数的值
    本文小编为大家详细介绍“C语言不使用临时变量怎么交换两个整数的值”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言不使用临时变量怎么交换两个整数的值”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。不使用临时变量...
    99+
    2023-06-17
  • Python变量的使用方法有哪些
    本篇内容介绍了“Python变量的使用方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!创建变量变量是存放数据值的容器。与其他编程语言...
    99+
    2023-07-05
  • javascript声明变量不用var的方法有哪些
    本篇内容主要讲解“javascript声明变量不用var的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript声明变量不用var的方法有...
    99+
    2022-10-19
  • python数据类型和变量的使用方法有哪些
    本篇内容主要讲解“python数据类型和变量的使用方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python数据类型和变量的使用方法有哪些”吧!数据类型计算机顾名思义就是可以做数学计算...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作