读书人

解惑一:基数性

发布时间: 2012-08-27 21:21:57 作者: rapoo

解惑1:基数性

[声明]所有代码均来自Joshua Bloch和Neal Gafter所著的<Java解惑>一书,本人仅因学习需要摘抄和注释,感谢二位作者的知识分享.

?

代码:

?

public class Oddity {    public static boolean isOdd(int i) {        return i % 2 == 1;    }    public static void main(String[] args) {    int i = 4;    System.out.println("Question: " + i + " is odd ? ");    System.out.println("Answer: " + isOdd(i));    }}

?

?

结果:

?

Question: 4 is odd ? Answer: false

?

?

分析:



结果竟然说4不是偶数?


取模运算当返回值为0时说明被整除

? ? ? 所以 偶数 % 2 = 0

取模运算当返回值非零时,它与左操作数具有相同的正负符号

? ? ? 所以 正奇数 % 2 = 1

? ? ? ? ? ? ? ?负奇数 % 2 = -1

所以通过取模运算判断奇数时可以改成用 i % 2 != 0 ?来判断.


??现在换一种思路来思考,所有的奇数的二进制最后一位必然为1,偶数的为0.

所以我们用1和参数进行按位与运算时,参数为奇数时与运算的结果为1,参数为偶数时与运算的结果为0


例如: ?4 & 1 ? ? ? ? 7 & 1


0100 ? ? ? ? ?0111

&0001 ? ? ? &0001

结果: ?0000(0) ? ? 0001(1)

?

解决方案代码:

?

public class Oddity {        public static boolean isOdd(int i){    return (i & 1) == 0;    }        public static void main(String[] args) {    int i = 4;    System.out.println("Question: " + i + " is odd ? ");    System.out.println("Answer: " + isOdd(i));    }}
?

?

结果:

?

Question: 4 is odd ? Answer: true
?

?

?

读书人网 >编程

热点推荐