热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

交换两个整数,不使用第三个变量

分析:异或运算,首先必须明确的是异或运算的特点a^bc,a^cb,b^ca,任意两个进行异或得到的第三个数,第三个数和自身异或即可得到另一个数。根据这个特点,适用的场景就多了,比如



分析:
异或运算,首先必须明确的是异或运算的特点a ^ b=c, a ^ c = b,b ^ c = a,任意两个进行异或得到的第三个数,第三个数和自身异或即可得到另一个数。根据这个特点,适用的场景就多了,比如本文的交换两个数、加密与解密等,特点就是高效,异或运算,移位运算其性能远远高于普通的加减乘除,这个可以自己去验证。提示:根据运算的次数能够大致估算出哪个更快。

#include
using namespace std
//交换两个变量的值,不使用第三个变量
int main()
{
int a = 12;
int b = 23;
cout <<"交换前的两个数为:";
cout <<"a=" < //因为不能使用第三个变量,也不能将异或的值,如果保存给当前的a或b,那么a或b的值只有一个可以发生变化,再异或下一个就不行了
cout <<"a=" <<((a ^ b) ^ a) <<" b=" <<((a ^ b) ^ b) < return 0;
}

运行结果:
在这里插入图片描述



推荐阅读
author-avatar
陈家小女u
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有