缘由:今天在刷题的时候遇到了一个问题,导致明明觉得思路没问题的代码就是通过率不到100%,经过反复推敲才知道问题所在,是因为部分案例溢出导致,这里就会设计一个概念——对数据取模。
这里的取模并非我们数学观念中的取绝对值 |f(x)| ,他有点像我们小学学的对一个数取余数,如 a % b = c …d ,这个d就是我们要求的余数,所以java的取模操作,对一个数a取模b就是a%b,但是取模操作又不仅仅等同于取余,他对其进行了一定程度的扩展,因为我们的计算机还要处理负数。我们的计算机取模操作一般就涉及到如下几种情况,让我们来看看吧:
- a % b (a>0,b>0,a>b)
- a % b (a>0,b>0,a<b)
- -a % b (a>0,b>0,a>b)
- -a % b (a>0,b>0,a<b)
- a % -b (a>0,b>0,a>b)
- a % -b (a>0,b>0,a<b)
- -a % -b (a>0,b>0,a>b)
- -a % -b (a>0,b>0,a<b)
案例代码:
System.out.println( 5 % 4 ); => 1
System.out.println( 4 % 5 ); => 4
System.out.println( -5 % 4 ); => -1
System.out.println( -4 % 5 ); => -4
System.out.println( 5 % -4 ); => 1
System.out.println( 4 % -5 ); => 4
System.out.println( -5 % -4 ); => -1
System.out.println( -4 % -5 ); => -4
取模总结:
我们的取模的时候可以将两个数都看作是正数,然后用小学的方法得出一个值,最终这个值需要和我们的被模数a保持同号即可,这就是java语言对于计算机取模操作的设计,其他语言会有不同。
结论:
我们取模的目的,在实际代码中一般都是用来防止数据的溢出,一旦对数进行取模,可以规避数据溢出的风险。