由于其他人已经给出了答案,我会添加一些额外的上下文。 %“模数”操作符实际上是在执行余数操作。 mod和rem的区别很微妙,但是很重要。
(-1 mod 2)通常会给出1.更具体地说,给定两个整数X和Y,操作(X mod Y)倾向于返回范围[0,Y)的一个值。 换言之,X和Y的模量总是大于或等于零,并且小于Y.
用“%”或rem运算符执行相同的操作将保持X值的符号。 如果X为负数,则得到范围(-Y,0)的结果。如果X是正数,则得到范围[0,Y)的结果。
通常这种微妙的区别并不重要。 回到你的代码问题,虽然有多种解决“均匀”的方法。
第一种方法对初学者很好,因为它特别详细。
// Option 1: Clearest way for beginners boolean isEven; if ((a % 2) == 0) { isEven = true } else { isEven = false }
第二种方法更好地利用语言,并导致更简洁的代码。 (不要忘记==运算符返回一个布尔值。)
// Option 2: Clear, succinct, code boolean isEven = ((a % 2) == 0);
第三种方法是完整的,并使用三元运算符。 尽pipe三元运算符通常非常有用,但在这种情况下,我认为第二种方法更为优越。
// Option 3: Ternary operator boolean isEven = ((a % 2) == 0) ? true : false;
第四种也是最后一种方法是使用整数的二进制表示的知识。 如果最低有效位是0,那么数字是偶数。 这可以使用按位和运算符 (&)进行检查。 虽然这种方法是最快的(你正在做简单的位掩码而不是分割),但对于初学者来说,这可能是一些先进/复杂的。
// Option 4: Bitwise-and boolean isEven = ((a & 1) == 0);
在这里,我使用了按位和操作符,并以选项2所示的简洁forms表示它。以选项1的forms(或者选项3的forms)重写它作为练习留给读者。 ;)
希望有所帮助。