java判断一个数字是否为偶数的几种方式
第一种:取余
function isOdd(n){
if(n%2==0){
console.log(n+'是偶数');
}else if(n%2==1){
console.log(n+'是奇数');
}else{
console.log(n+'不是整数');
}
}
console.log(isOdd(3))
第二种:位运算符&
function isOdd(n){
if(n&1){
console.log(n+'是奇数');
}
if(!(n&1)){
console.log(n+'是偶数');
}
}
console.log(isOdd(3))
解析:&会将数字转成2进制进行运算,0----000,1----001,2----010,3----011,4—100,以此类推。3&1等价于011&001,&是按位进行运算,两者都为1才是1,否则为0(运算规则:0&0=0; 0&1=0; 1&0=0; 1&1=1;),所以011&001=001等价于十进制的1,所以为奇数,偶数运算后等于十进制的0.
第三种:异或运算符^
function isOdd(n){
if((n^1)==n-1){
console.log(n+'是奇数');
}
if((n^1)==n+1){
console.log(n+'是偶数');
}
}
console.log(isOdd(3))
解析:也是将数字转换成二进制运算,只要两者不同才为1,否则为0(运算规则:00=0; 0^1=1; 1^0=1; 11=0;),011001=010等价于十进制的2,所以为奇数,偶数运算后等于本身加1.
注意:==优先级高于,所以需要给n1加上括号
第四种:递归
function isOdd(n){
if(n<0||n==1){
return '奇数'
}
if(n==0){
return '偶数'
}
return isOdd(n-2)
}
console.log(isOdd(3))
解析:通过递归减去2,若是偶数则减去2最终为0,若是奇数减去2最终为1或负数。