异或详解
来源:互联网 发布:进程调度算法实验报告 编辑:程序博客网 时间:2024/04/29 18:50
异或门符号'^',在编程中的使用,有的时候能够让你的程序更加精炼简捷,
尤其在C++的acm程序应用中,可以避免许多麻烦!!!它的几个简单作用
讲解如下:
它的简单规则是相同为0,不同为1,例如
int a=3=011(2进制,在计算机中的存储形式);
int b=6=110(2进制,在计算机中的存储形式);
int c=a^b=101=5;
切忌,在异或门的计算中都是应用的2进制!!
任何数和0异或都等于它本身;两个相同的数异或后的结果是0;
1)实现两个数的交换
a=a^b;
b=a^b;//b=a^b^b=a^0=a;
a=a^b;//a=a^a^b=0^b=b;
应用例子如下:
#include<iostream>
using namespace std;
int main()
{
int a=3;
int b=4;
a=a^b;
b=a^b;
a=a^b;
cout<<a<<' '<<b<<endl;
return 0;
}
2在一排数中找到独一无二的一个数
例子如下:
他的思路是;
只要有相同的数那么他们异或后的结果就是0,最后就剩下0和那个独一无二的数相异或,就等于
那个独一无二的数了!!哈哈!!例子,如下:
#include<iostream>
using namespace std;
int main()
{
int n,i,x,y;
while(scanf("%d",&n)!=EOF&&n)
{
x=0;
while(n--)
{
cin>>y;
x^=y;
}
printf("%d\n",x);
}
return 0;
}
随便输入几个数,找到其中没有和他相同的那个数!!哈!
3)判断两个数是否相等
if(a^b==0)
printf("a=b");
else
printf("a!=b");
- 异或详解
- 异或详解
- 异或运算详解
- 异或运算详解及经典应用
- C、C++ 中 |、||、&、&&、异或、~、!运算详解
- JAVA_java的位运算符详解实例(与& 非~ 或| 异或^)
- java 的位运算符详解实例 ------与(&) 、或( |) 、非( ~) 、异或( ^)
- Java的位运算符详解实例-与(&)、非(~)、或(|)、异或(^)
- java 位运算符详解 及 实例 ---与(&),或(|),非(~),异或(^)
- iOS开发之 异或加密的原理详解
- 与, 或, 异或
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)
- Python数据类型 -- 字典
- UIScrollVIew和UIPageControl学习使用
- SecureCRT上传、下载文件(使用sz与rz命令)
- Python数据类型 -- 基本数据结构习题
- C++ Primer Plus简单解析
- 异或详解
- Guava Collections使用介绍[超级强大]
- HTML5 Web存储(localStorage与sessionStorage)
- 中英文混合排序
- Windows下安装NodeJs
- Java线程(七)-线程的调度
- java保留两位小数4种方法
- epoll模型
- iOS tableView 的headerView 可拉伸效果