`
zhaohaolin
  • 浏览: 1011324 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

变量互换

    博客分类:
  • JAVA
阅读更多

今天在CSDN上看到一个帖子,标题是最经典的代码,很多人都发了自己认为很经典的代码。但是大多都吸引不了我的眼球。
 
  在往后翻了几页后,有一串代码,确实让我震撼了。
 
  a ^= b; b ^= a; a ^= b;
 
  就这三句,实现了 a b 两个变量的交换。
 
  以前我们传统的交换两个变量值的方法是用一个临时变量来进行过渡:
 
  temp = a; a = b; b = temp;
 
  而上面的语句却在两个变量之间进行了转换,感觉很奇妙,所以我特地的用PHP写了一个小程序,来分析他的运算过程:
 
  首先,来讲一讲 a ^= b; b ^= a; a ^= b; 的运算符,他用的是“ ^ 按位异或运算”。
 
  什么是异或运算呢?
 
  他是在计算机应用中,普遍运用,异或的逻辑符号 ^ (Shift + 6)。形象表示为:
  真 ^ 假 = 真
  假 ^ 真 = 真
  假 ^ 假 = 假
  真 ^ 真 = 假
 
  可以看到,当两个条件相同时,结果为假;当两个条件不同是,结果为真。
 
  好,我们现在来举个例子演示一下他的运算过程
 
  定义变量 a = 21, b = 45;
 
  a 转换成8位二进制:0001 0101
  b 转换成8位二进制:0010 1101
 
  运算过程:
第一句:a ^= b;   等效于 a = a ^ b;
    二进制运算过程:
    0001 0101 a=21
    ^0010 1101 b=45
     --------------
    0011 1000 a=56 (此时的 a 已经变成了 0011 1000 转换成十进制:56)
 
第二句:b ^= a;   等效于 b = b ^ a;
    二进制运算过程:
    0010 1101 b=45
    ^0011 1000 a=56
     --------------
    0001 0101 b=21 (此时的 b 已经变成了 0001 0101 转换成二进制:21。已经将变量a的值换到变量b里去了。)
 
第三句:a ^= b;   等效于 a = a ^ b;
    二进制运算过程:
    0011 1000 a=56
    ^0001 0101 b=21
     --------------
    0010 1101 a=45 (此时的 a 已经变成了 0010 1101 转换成二进制:45。已经将变量b的值换到变量a里去了。)
 
  嘿嘿,两个变量就这么轻而易举的交换了,是不是很奇妙啊。哈哈……
 
  下面我吧我写的PHP程序放上来,让大家调试了看看:
  
  以下代码可以直接复制后运行 (PHP Version 5.2.6 Windows XP)

CODE:



<?php

echo "演示 a ^= b; b ^= a; a ^= b; 交换两个变量值的过程:<br><br>";
$a = 21;
$b = 45;

echo "a = " . $a . " 转换成8位二进制:" . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . "<BR>";
echo "b = " . $b . " 转换成8位二进制:" . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . "<BR><BR>";

echo "运算 a ^= b; 等同于 a = a ^ b;<br>";
echo "    " . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . " a = " . $a . "<br>";
echo "    ^" . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . " b = " . $b . "<br>";
echo "    --------<br>";
$a = $a ^ $b; // 执行第一句运算语句 并将结果赋给变量 a
echo "    " . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . " a = " . $a . "此时的 a 已经变成了 0011 1000 转换成十进制:56<br><BR>";

echo "运算 b ^= a; 等同于 b = b ^ a;<br>";
echo "    " . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . " b = " . $b . "<br>";
echo "    ^" . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . " a = " . $a . "<br>";
echo "    --------<br>";
$b = $b ^ $a; // 执行第二句运算语句 并将结果赋给变量 b
echo "    " . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . " b = " . $b . "已经将变量a的值换到变量b里去了<br><BR>";

echo "运算 a ^= b; 等同于 a = a ^ b;<br>";
echo "    " . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . " a = " . $a . "<br>";
echo "    ^" . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . " b = " . $b . "<br>";
echo "    --------<br>";
$a = $a ^ $b; // 执行第三句运算语句 并将结果赋给变量 a
echo "    " . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . " a = " . $a . "已经将变量b的值换到变量a里去了<br><BR>";

echo "输出运算结果:<br>";
echo "a = " . $a . " 转换成8位二进制:" . str_pad(decbin($a), 8, "0", STR_PAD_LEFT) . "<BR>";
echo "b = " . $b . " 转换成8位二进制:" . str_pad(decbin($b), 8, "0", STR_PAD_LEFT) . "<BR><BR>";

?>
运算结果:
演示 a ^= b; b ^= a; a ^= b; 交换两个变量值的过程:
a = 21 转换成8位二进制:00010101
b = 45 转换成8位二进制:00101101
运算 a ^= b; 等同于 a = a ^ b;
    00010101 a = 21
    ^00101101 b = 45
    --------
    00111000 a = 56此时的 a 已经变成了 0011 1000 转换成十进制:56
运算 b ^= a; 等同于 b = b ^ a;
    00101101 b = 45
    ^00111000 a = 56
    --------
    00010101 b = 21已经将变量a的值换到变量b里去了
运算 a ^= b; 等同于 a = a ^ b;
    00111000 a = 56
    ^00010101 b = 21
    --------
    00101101 a = 45已经将变量b的值换到变量a里去了
输出运算结果:
a = 45 转换成8位二进制:00101101
b = 21 转换成8位二进制:00010101

 

 

 

两变量互换不借助第三变量
2011-03-13 23:34

1.异或

a = a ^ b;

b = b ^ a;

a = a ^ b;

 

2.加减

a = a + b;

b = a - b;

a = a - b;

 

3.乘除

a = a * b;

b = a / b;

a = a / b;

 

4.

a + b - (b = a);

分享到:
评论

相关推荐

    java使用异或实现变量互换和异或加密解密示例

    在编程领域,异或(XOR)运算符是一种非常有用的逻辑运算符,它在很多场景中都有应用,比如变量互换、数据加密和解密等。本文将详细讲解如何使用Java中的异或运算来实现变量互换以及异或加密解密。 首先,我们来看...

    两变量值互换

    在编程领域,两变量值互换是一个常见的操作,特别是在需要临时保存一个变量的值以便后续处理的情况下。在标题“两变量值互换”中提到的方法,实际上是指在不借助额外辅助变量的情况下,通过位运算来实现两个变量的值...

    不使用第三个变量进行交换的三种方式以及隐藏隐患

    在不使用第三个变量交换两个变量的值时,常见的方法有三种,分别是利用加法和减法,利用异或运算,以及利用位运算。这三种方法各自有不同的特点和潜在问题,以下是详细的知识点。 ### 1. 利用加减法交换变量 加...

    Java两个变量的互换(不借助第3个变量)具体实现方法

    System.out.println("执行变量互换..."); // 使用异或操作交换A和B的值 A = A ^ B; B = A ^ B; A = A ^ B; System.out.println("A=" + A + "\t" + "B=" + B); } } ``` 在这个程序中,我们首先从用户那里...

    Java中使用异或语句实现两个变量的互换

    System.out.println("执行变量互换后......"); A = A ^ B; // 第一步:A和B进行异或操作,结果存储回A B = A ^ B; // 第二步:此时的A(第一步的结果)和B进行异或,结果存储回B A = A ^ B; // 第三步:再次用...

    2023年全国计算机二级C语言程序改错题.doc

    * 程序改错题中变量互换问题的特点:在程序改错题中,变量互换问题通常涉及到变量的定义、赋值和交换等操作。 知识点四:最大公约数问题 * 最大公约数概念:最大公约数是指两个或多个数的公共因子中最大的那个。 *...

    计算机数字逻辑复习试卷

    对偶式是将逻辑运算中的与变为或,或变为与,原变量与反变量互换。 4. 组合逻辑电路与时序逻辑电路: 组合逻辑电路由门电路组成,如译码器、编码器、全加器等,它们的输出仅取决于当前输入,无记忆功能。时序逻辑...

    python实验2(含代码/截图/总结)

    - 使用 x,y = y,x 语句实现变量互换 - 了解 Python 中变量的赋值方式 4. 编写程序,演示 Python 字符串中和判断有关的方法的使用 - 使用 isalnum()、isalpha()、isdigit()、islower()、isupper()、istitle() 和 ...

    matlab 刘卫国 第4章例题源程序

    变量互换可以使用临时变量,例如 `c = a; a = b; b = c;` 将变量 a 和 b 的值互换。 函数编程 Matlab 中的函数可以使用 `function` 关键字定义,例如 `function [a, b] = exch(a, b)` 将变量 a 和 b 的值互换。函数...

    python 两个变量值互换(示例)

    # 题目: # 两个变量值互换。

    全国计算机二级C语言程序改错题_100%全中必过.doc

    3. **变量互换问题**:常见的互换方法有XOR操作、中间变量法和指针法。考生需了解每种方法的原理,避免在没有中间变量的情况下出错。 4. **最大公约数问题**:可以使用欧几里得算法,通过不断求余数直至余数为0来...

    JavaSE知识点总结(个人整理).docx

    11. **变量互换**:不借助第三方变量,可以通过异或运算符`^`实现两个变量的值互换。 12. **迭代器**:用于遍历集合中的元素,还可以删除集合中的元素。 13. **线程状态**: - 新建(new) - 就绪(runnable) ...

    2013年高中数学《1.2.1 输入语句、输出语句和赋值语句》练习 新人教A版必修3

    4. **变量互换**:在算法中经常遇到需要交换两个变量值的情况,如题目中的例子“a=8,b=17 交换,使 a=17,b=8”。正确的互换方法是借助第三个临时变量,或者通过算术运算实现。 5. **条件判断**:虽然题目中...

    数字电路习题讲评PPT学习教案.pptx

    - 反演定理描述的是,如果将逻辑表达式中的逻辑运算符和常数值进行相反的替换(逻辑乘变加,加变乘,0变1,1变0),同时变量和其反变量互换,得到的新表达式就是原表达式的反演形式,记作Y'。 - 应用反演定理时...

    第三章 运输问题.pdf

    如果不是,需要进行换基操作,即选择一个非基变量和一个基变量互换位置,并重新计算,以改进当前解。 运输问题的系数矩阵描述了问题中的所有可能的运输路线以及对应的运输成本。系数矩阵的元素cij表示从产地Ai到销...

    全国计算机二级C语言程序改错题必过.doc

    题目三:变量互换问题 在C语言中,有多种方法可以交换两个变量的值,如使用临时变量、异或操作、加减操作等。错误可能出现在忘记初始化变量、使用错误的操作符、或者在某些情况下没有考虑到溢出问题。 题目四:最大...

    上海市上海实验学校2020届高三数学上学期9月月考试题含解析

    5. 反函数的求法:反函数是原函数的逆运算,要求出反函数,就需要解出原函数中的自变量,然后将自变量和因变量互换位置。 6. 函数值域的求解:函数在某一区间的值域是其在这个区间内所有可能取到的值的集合。对于...

    初中数学竞赛——轮换式和对称式.doc

    在任何两个变量互换后依然保持不变。 二、轮换式与对称式的分解方法 对于轮换式和对称式的分解,通常采用以下步骤: 1. 试根法:将多项式视为单个字母的多项式,寻找可能的因式。 2. 轮换特性:利用轮换式的特点...

    2022届高考数学函数部分选择题1宣贯.pdf

    求反函数时,通常需要将原函数中的变量互换位置,并解出新变量。 3. 函数的极限:第7题涉及到了三次函数的极限问题,通过设定函数的一般形式并利用极限性质来求解。 4. 函数的单调性:第3题和第10题讨论了函数单调...

Global site tag (gtag.js) - Google Analytics