在代码开发中,我们应该做到 “知其然,并知其所以然”。
判断一个数是奇数还是偶数是小学里学的基本知识,在代码开发中,一个数字是否是偶数,只需要判断是否能被2整除,那你会有几种写法呢?
int a = 10; int flag = a % 2; if (flag == 0) { System.out.println("是偶数"); } else { System.out.println("是奇数"); }
或者还可以这样写:
int a = 10; int flag = a % 2; if (flag == 1) { System.out.println("是奇数"); } else { System.out.println("是偶数"); }
对于这个例子来讲,两种运行效果是一致的:
然后我们来升级一下,动态的输入奇偶数来判断:
public static void mn(String[] args) { //接收键盘输入参数 Scanner input = new Scanner(System.in); System.out.println("请输入多个数字判断奇偶"); while (input.hasNextInt()) { int a = input.nextInt(); int flag = a % 2; if (flag == 1) { System.out.println(a+" => 是奇数"); } else { System.out.println(a+" => 是偶数"); } } }
当输到-1、-3时,结果就出错了,这和Java中的取余计算算法有关系:
/** * 取余计算 Java 处理取余原理 * * @param dividend 被除数 * @param divisor 除数 * @return */ public static int remainder(int dividend, int divisor) { return dividend - dividend / divisor * divisor; }
根据上面的方法,当输入-1时,计算结果是 -1,不等于1,所以结果就被判定为偶数了,我们修改一下判断方式:
在计算机语言中,% (或mod) 是一个常见的数学运算符,但不同的计算机语言对 % 有不同的定义,有的语言把 % 定义为取模,有的则把 % 定义为取余。
在中文体系下,取模和取余的定义不同1,在英文体系中,只有一个模运算 (Modulo operation)2,但是有最小正余数 (the least positive remainder) 和最小绝对余数 (the least absolute remainder) 的概念。
在 Java 中,% 代表的是取余。如果要进行取模,可以用 Math.floorMod() 方法。