首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

java 实现 按_Java的性质及其妙用

文章摘要: 1、按,可以简单理解成:不进位加法。即:1+1=0;0+0=0;1+0 =1; 2、任何数和自己结果为零。 3、按自反性。两次运算操作,可以将最后的结果还原。...4、任何数和0做值不变,和1结果为原操作数取反。 5、交换律。不使用中间变量,交换两个数。 一、按具有自反性。即:对同一个数据,进行两次按操作,等于数据本身。...【只允许使用按】 分析: 1、连续两次操作电灯开关,电灯将处于操作前状态。 2、关闭所有开关。任何数和自己结果为零。 实现: 1、定义“大房子”类。...大房子.次卧灯); hourse.操作电灯开关(大房子.走廊灯); //5、一键关闭所有灯 hourse.让所有的灯关闭(); System.out.println(hourse); 三、总结: 妙用按...本例演示了按的自反性,还有其他妙用,我们可以总结如下: 1、按,可以简单理解成:不进位加法。即:1+1=0;0+0=0;1+0 =1; 2、任何数和自己结果为零。

1.2K20

java中的运算符_java

的规则是转换成二进制比较,相同为0,不同为1....一个数a与另一个数b的结果等于a^b,用结果( a^b)a,就会得到b; 上面的结果,我们用代码来验证。代码( a=a^b; b=a^b; a=a^b;)可以转换成二进制计算。...a=a^b ; ———— 01=10^11 第一步得到结果C( a^b)赋值给a,所以a此时等于01 b=a^b; ———— 10=01^11 第二步 用结果( a^b)b,即用C(01)b(...a=a^b; ————-11=01^10 第三步,a(01)b(10),等于11。转为十进制a等于3. 最后打印出来,a等于3, b等于2. 第二种:用规则计算。 (规则:可以移动。...相同数等于0,任何数0等于本身) 第一步没变化,直接代入后面的代码进行计算。 第二步中b=a^b的 a^b转化为 a^b ^b ,其中让b^b等于0, a^0等于a。

1.9K10
您找到你想要的搜索结果了吗?
是的
没有找到

java的运算是,深入理解按运算符

即: 0^0 = 0, 1^0 = 1, 0^1 = 1, 1^1 = 0 按的3个特点: (1) 0^0=0,0^1=1 0任何数=任何数 (2) 1^0=1,1^1=0 1任何数-...任何数取反 (3) 任何数自己=把自己置0 按的几个常见用途: (1) 使某些特定的翻转 例如对数10100001的第2和第3翻转,则可以将该数与00000110进行按运算。...说明 ^ 运算符查看两个表达式的二进制表示法的值,并执行按。...运算就是二进制整数运算啦. 两个数按意思就是从个位开始,一的比....如果两个数相应的上一样,结果就是0,不一样就是1 所以111^101=010 那加密的过程就是逐个字符跟那个secret字符运算.

88620

与(&)、(|)、(^) – 运算详解

,寄希望下次看到的时候能立马想起来而不是再去理解一次 运算符 含义 描述(运算,基于二进制表示) 示例 & 按与 只有参与运算的两均为1时,结果才为1,否则为0 a与b:$a & $b | 按...只有参与运算的两均为0时,结果才为0,否则为1 ab:$a | $b ^ 按 只有参与运算的两不同时,结果才为1,否则为0 ab:$a ^ $b ~ 按非(取反) 将用二进制表示的操作数中为...1的转为0,为0的为转为1 a非:~$a << 左移 将左边的操作数在内存中的二进制数据向左移动指定位数,右侧移空的用0补齐 a左移4:$a<<4 >> 右移 将左边的操作数在内存中的二进制数据向右移动指定位数...,左侧移空的用0补齐 a右移4:$a>>4 图示说明: 定义: A=81(d)=01010001(b) B=9(d)=00001001(b) 按与(&) 规则:0&0=0,0&1=0,1&0=0...,1&1=1 A&B运算结果:1(d)=00000001(b) 按(|) 规则:0|0=0,0|1=1,1|0=1,1|  1=1 A|B运算结果:89(d)=01011001(b) 按(

1.3K20

java_java中的

一、介绍 或是一种基于二进制的运算,用符号XOR或者 ^ 表示,其运算法则是对运算符两侧数的每一个二进制,同值取0,值取1。...性质 1、交换律 2、结合律(即(a^b)^c == a^(b^c)) 3、对于任何数x,都有x^x=0,x^0=x 4、自反性 A XOR B XOR B = A XOR 0 = A 二、使用 运算最常见于多项式除法...解法二:就没有这个问题,并且性能更好。将所有的数全部,得到的结果与1^2^3^…^1000的结果进行,得到的结果就是重复数。 但是这个算法虽然很简单,但证明起来并不是一件容易的事情。...这与运算的几个特性有关系。首先是运算满足交换律、结合律。 所以,1^2^…^n^…^n^…^1000,无论这两个n出现在什么位置,都可以转换成为1^2^…^1000^(n^n)的形式。...所以,将所有的数全部,得到的结果与1^2^3^…^1000的结果进行,得到的结果就是重复数。

3.3K21

运算之(XOR)

Table of Contents XOR是什么 XOR的运算规则 XOR的应用 References XOR是什么 是计算机的逻辑运算 XOR的运算规则 相同为0, 不同为1 1000 ^ 1001...的运算过程如下 1001 1000 =0001 XOR的应用 ---- 判断两个数是否相等 通过判断两个数结果是否为0来判断两个数是否相等 int a=10,b=20,c=10; a^b...x-1 是为了找出最右侧1的位置, // x & (x - 1) 是将从右侧的位置开始的位置为0 // ^ 是根据相同为0, 不同为1, 最右侧之前的位置为0 HashMap的hash算法 // java8...0 : (h = key.hashCode()) ^ (h >>> 16); } //h >>> 16 是为了将高位移向地位 //运算 是因为index = (n-1) &...hash; n是数组的长度, 为了防止hash散列冲突 //java7的是hash % n, java8用无符号右移是因为运算快 References https://hackernoon.com

1.6K10

java运算符_python

Java-运算 运算法则 的运算方法是一个二进制运算: 例图: 总结 例题1 例题2:136....的运算方法是一个二进制运算: 1^1=0 0^0=0 1^0=1 0^1=1 两者相等为0,不等为1. 例图: 总结 1、或是一个数学运算符。应用于逻辑运算。...2、真假的结果是真,假真的结果也是真,真真的结果是假,假假的结果是假。就是说两个值相异结果为真。...3、n^0=n n^n=0,即任何数与0进行,为它本身,两个相同的数进行运算,会得到0。...所以,我们对于上边的解题办法就有了: 首先对1到1000,这1000个数进行运算,然后再把上边的1001个数进行运算,最后,再对这两个结果进行运算,就会得到唯一的那个n。

1.6K30

逻辑与(&&)、逻辑(||)、按与(&)、按(|)、按(^)、按取反(~)

逻辑(||) 运算符两边的表达式的值都为false运算结果为false, 其余情况为true。 按与(&) 计算方法: 参加运算的两个数,换算为二进制(0、1)后,进行与运算。...只有当 相应上全部为1时取1, 存在0时为0。 011 & 110 011 110 --- 010 按(|) 计算方法: 参加运算的两个数,换算为二进制(0、1)后,进行运算。...只要当 相应上存在1时取1, 全部为0时为0。 011 | 110 011 110 --- 111 按(⊙) 计算方法: 参加运算的两个数,换算为二进制(0、1)后,进行运算。...只有当 相应上的数字相同时取1, 不相同为0。 011 ⊙ 110 011 110 --- 010 按(^) 计算方法: 参加运算的两个数,换算为二进制(0、1)后,进行运算。...2)<5; cout<<a<<" "<<b<<endl; //输出0 1 int c = 1ll<<3; cout<<c<<endl; //输出8 ll防止在往前移位的时候爆掉int 运算的性质

1.5K30

Java运算符详解实例——与(&)、非(~)、(|)、(^)

运算符主要针对二进制,它包括了:“与”、“非”、“”、“”。...运算符是用符号“^”表示的,其运算规律是: 两个操作数的中,相同则结果为0,不同则结果为1。...:"+(a^b)); } } 运行结果 a 与 b 的结果是:13 分析上面的程序段:a 的值是15,转换成二进制为1111,而b 的值是2,转换成二进制为0010,根据的运算规律,可以得出其结果为...运算是对整数的二进制进行相关操作,详细运算如下: 非运算值表 A~A10  0 1 与运算值表 ABA&B111100010000 运算值表 ABA | B111101011000...运算值表 ABA&B110101011000 示例如下: [java] view plain copy int a=15;   int b=2;   System.out.println(

1.1K10

c语言中按运算,^按运算符「建议收藏」

^表示按运算符,顾名思义,相异,即不同则为1,反之为0 例如15和16进行运算,运算过程如下:15 0000 0000 0000 0000 0000 0000 0000 1111 16...0000 0000 0000 0000 0001 0000 ^ —————————————— 0000 0000 0000 0000 0000 0000 0001 1111 可以看到,经过按运算后...大家务必弄清楚运算过程,然后再上机验证,代码如下:#include int main() { int a; a=15^16; printf(“a=%d\n”,a); return 0; } 运算结果为:a=31 运算符的作用指定位数的翻转...如想对某个数字的低4进行翻转,则可以将这个数字与15(二进制为00001111)进行按运算,既可以将原数字的低四进行翻转,即高四不变,低四0变1,1变0 与0还是原值 大家可以自行实验...,一个数字与0进行,结果还是原值 交换两个数字 除了之前我们学习交换两个数字需要第三个变量做中介之外,如今可以通过运算进行,代码如下:#include int swap(int *a,int *

1.1K20

与、等运算方法

运算符(|) 参加运算的两个对象,按二进制进行“”运算。...例:将X=10100000的低4置1 ,用 X | 0000 1111 = 1010 1111即可得到。 运算符(^) 参加运算的两个数据,按二进制进行“”运算。...“运算”的特殊作用: (1)使特定位翻转找一个数,对应X要翻转的各位,该数的对应为1,其余为零,此数与X对应即可。...例:X=10101110,使X低4翻转,用X ^ 0000 1111 = 1010 0001即可得到。 (2)与0相,保留原值 ,X ^ 0000 0000 = 1010 1110。...本文由来源 21aspnet,由 javajgs_com 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同支持。

1.6K30

与& | ^ 的日常使用

与: 0&0=0; 0&1=0; 1&0=0; 1&1=1; 按: 0|0=0; 0|1=1; 1|0=1; 1|1=1; 按,在的基础上1 1也为0:...0^0=0; 0^1=1; 1^0=1; 1^1=0; 1.一个int型字段,存储十进制的数字,比如说是5 那么该数字转成二进制是101,我自己定义从左往右数, 第一1,代表某功能自动转发开启...第二0,代表自动删除关闭 第三1,代表自动保存开启 2.判断第三是否开启自动保存的代码 ($userStatus & pow(2,3-1))!...=0 3.pow是指数表达式函数,2的2次方,转成二进制是0100,按与0101 & 0100 是0100 十进制为4,因此不等于0为true 4.设置某一的值,如果要设置为1代码是 $userStatus...| pow(2,3-1) 原始值为 0001,要设置第三为1,0001 | 0100 为0101 5.把某一设置为0,代码是 $userStatus ^ pow(2,3-1) 0101 ^ 0100

1K20

C语言 按运算

运算: 规律:无论01,1取反,0不变 变量交换: 题一:给定两个数 a 和 b ,用运算交换它们的值。...思路: 1)中间量t = a^b 2) b = tb,相当于abb,根据性质知道ab^b = a,所以b = t^b就是b = a (性质:两次不变) 3)a = t^a,道理同上...思路: 根据的性质,两个一样的数结果为零。也就是所有出现偶数次的数都为零,那么把这 n 个数都一下,得到的数就一定是一个出现奇数次的数了。...这里最终偶数次的数偶数次的偶数结果为0,0再奇数次的数结果为其本身,就是这个道理 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/141615.html原文链接

1.3K30

C的|、||、&、&&、、~、!运算 运算

运算符有: &(按与)、|(按)、^(按)、~ (按取反)。 ~取反为单目,其余都是双目运算符。...1,该位的结果值为1 ^ 按 若参加运算的两个二进制值相同则为0,否则为1 ~ 取反 ~是一元运算符,用来对一个二进制数按取反,即将0变1,将1变0 << 左移 用来将一个数的各二进制全部左移...若要把这结果赋给变量j,可写成: j = 017|j (3)按运算符(^) 按运算将两个运算分量的对应遵照以下规则进行计算: 0 ^ 0 = 0, 0 ^ 1 = 1, 1 ^ 0 =...运算的意思是求两个运算分量相应值是否相异,相异的为1,相同的为0。按运算的典型用法是求一个串信息的某几位信息的反。...如欲求整型变量j的最右4信息的反,用逻辑运算017^j,就能求得j最右4的信息的反,即原来为1的,结果是0,原来为0的,结果是1。

1.4K30
领券