判断一个数字是否为偶数的几种方式

第一种:取余

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(运算规则:0^0=0; 0^1=1; 1^0=1; 1^1=0;),011^001=010等价于十进制的2,所以为奇数,偶数运算后等于本身加1.

注意:==优先级高于^,所以需要给n^1加上括号

第四种:递归

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或负数。

你可能感兴趣的:(判断一个数字是否为偶数的几种方式)