Java别说取余(%)运算简单,你真的会吗?

Java别说取余(%)运算简单,你真的会吗?一,直击现场下面我来抛出几道题:说明m是商,n是余数;(1)正数%正数3%2=m…….n2%3=m…….n(2)正数%负数或者负数%正数-3%2=m…….n3%-2=m…….n-2%3=m…….n2%-3=m…….n(3)负数%负数-3%-2=m…….n-2%-3=m…….n二,验证时刻下面的结果没有商m只有余数n;有没有全部答对呢?没有的话来看总结吧

大家好,又见面了,我是你们的朋友全栈君。

前言:发现有不少人阅读了这篇文章,并且,指出了文章中存在的问题。其实,我本人好久之前也觉得文章的介绍有部分问题,且不够简洁,一直想着做出修改,却一拖再拖。最近两天(2021年7月22日),又接触了取模和取余的相关知识,同时取模和取余有相似之处,也都很容易遇到,所以一起介绍。觉得时机成熟了,是时候对本文做出完善了。

一 取余和取模的定义

对于整型数a,b来说,取模运算或者取余运算的方法都是:

  1. 求整数商: c = a/b
  2. 计算模或者余数: r = a – c*b

取余运算在取c的值时,向0的方向舍入;取模运算在计算c的值时,向负无穷方向舍入

如下图所示:如果c(即a/b的商)的结果为正数,如1.5,那么对于取余和取模的处理是相同的,c舍入后的结果都为1;如果c的结果为负数,如-1.5,那么对于取余是向0的方向舍入,c舍入后的结果为-1,但是,对于取模是向负无穷的方向舍入,舍入后的结果为-2;

在这里插入图片描述
取个例子,3 % -2
c = a / b = 3/-2 = -1.5 c向0的方向舍入为-1
r = a – c * b = 3 – (-1) * (-2) = 1
即3 % -2 = 1

二 取余的规律总结

考虑了a和b可能出现的几乎是所有的情况(除了a等于b的情况,其取余等于0),这样总结的规律更有普遍性。

package com.company.app;

public class RemTest { 
   
    public static void main(String[] args) { 
   
        // a的绝对值大于b
        System.out.println(" 2 % 3 = " + 2 % 3);
        System.out.println("-2 % 3 = " + (-2) % 3);
        System.out.println(" 2 %-3 = " + 2 % (-3));
        System.out.println("-2 %-3 = " + (-2) % (-3));

        System.out.println();

        // a的绝对值小于b
        System.out.println(" 3 % 2 = " + 3 % 2);
        System.out.println("-3 % 2 = " + (-3) % 2);
        System.out.println(" 3 %-2 = " + 3 % (-2));
        System.out.println("-3 %-2 = " + (-3) % (-2));

    }
}

运行结果如下:
在这里插入图片描述
规律:先使用a的绝对值和b的绝对值进行取余运算(或理解成先去掉符号也可以,并且两个正数的取余运算相对容易),然后取余的结果正负号和a保持一致。

我们可以进一步总结出如果a的绝对值小于b的绝对值,则余数就是a。本质还是通过上面的规律计算出来的。

有时候面试题中会让我们计算a/b的商和余数,我们根据上面的计算结果继续总结(可以验算 除数=商*被除数 + 余数):

表达式 除数a / 被除数b 余数
2 / 3 0 2
-2 / 3 0 -2
2 / -3 0 2
-2 / -3 0 -2
3 / 2 1 1
-3 / 2 -1 -1
3 / -2 -1 1
-3 / -2 1 -1

当a的绝对值小于b时,商0,余数为a;
当a的绝对值大于b时,先使用a的绝对值和b的绝对值进行运算,得出商和余数。商的符号,除数a和被除数b的符号相同则为正,不同则为负。余数的符号取决于除数a。

三 取模的规律总结

Java编程语言的%运算实现的是取余运算,而Python编程语言的%运算实现的是取模运算(注意,虽然使用符号相同,但是表示的却是不同的运算)。目前,还未学习Python,本地没有编程环境,使用在线的编辑器运行该代码及其运行结果如下所示:
请添加图片描述

表达式 a mod b (这里mod 表示取模运算)
2 mod 3 2
-2 mod 3 1
2 mod -3 -1
-2 mod -3 -2
3 mod 2 1
-3 mod 2 1
3 mod -2 -1
-3 mod -2 -1

当a和b同号时,先用|a|取余|b|,结果和b的正负号保持一致;

举个例子(下列例子中%表示取余运算,mod表示取模运算,|a|表示a的绝对值,或者理解为去除正负号的a,我们关心的是数值):

a mod b
2 mod 3 --> 2 % 3 = 2 --> 2 (结果和b的正负号保持一致,下同不赘述)
3 mod 2 --> 3 % 2 = 1 --> 1
-2 mod -3 --> 2 % 3 = 2--> -2
-3 mod -2 --> 3 % 2 = 1 --> -1

当a和b异号时,使得|b|>|a|(即如果|b|<|a|,就累加|b|,直达|b|>|a|)然后|b|-|a|,结果和b的正负号保持一致;

a mod b
-2 mod 3 --> 3 - 2 = 1 --> 1(结果和b的正负号保持一致,下同不再赘述)
2 mod -3 --> 3 - 2 = 1 --> -1
3 mod -2 --> (2 < 3,累加|b|) (2 + 2) - 3 = 1 --> -1 
-3 mod 2 --> (2 < 3,累加|b|) (2 + 2) - 3 = 1 --> 1

对上述累加|b|进一步说明,如果100 mod -3,累加3直到大于100为止,这只是为了方便描述,我们一眼可以看出33 * 3 < 100,那这个数就是34 * 3呗。本质就是n|b|>|a|,求n最小值,n|b|就是我们最终要的值。

最后,检测一下自己学会了吗?

表达式中%表示取余或取模 取余结果 取模结果
3 % 7
-3 % 7
3 % -7
-3 % -7
7 % 3
-7 % 3
7 % -3
-7 % -3

下滑查看答案,也可以自己编程验证:)


2021-7-22更新: 一 取余和取模的定义 二 取余的规律总结

2021-10-12更新: 三 取模的规律总结


四 答案

表达式中%表示取余或取模 取余结果 取模结果
3 % 7 3 3
-3 % 7 -3 4
3 % -7 3 -4
-3 % -7 -3 -3
7 % 3 1 1
-7 % 3 -1 2
7 % -3 1 -2
-7 % -3 -1 -1


以下内容同上,不建议阅读


一,直击现场

下面我来抛出几道题:
说明m是商,n是余数;
(1)正数%正数
3%2=m…n
2%3=m…n
(2)正数%负数或者负数%正数
-3%2=m…n
3%-2=m…n
-2%3=m…n
2%-3=m…n
(3)负数%负数
-3%-2=m…n
-2%-3=m…n

二,验证时刻

下面的结果没有商m只有余数n;有没有全部答对呢?没有的话来看总结吧
这里写图片描述

三,总结

(1)
3%2=1…1
2%3=0…1
正数除以正数:

商正余正

(2)
-3%2=-1…-1
3%-2=-1…1
-2%3=0…-2
2%-3=0…2
除数或者被除数其中之一为负数:

先按正数计算,商负余同被除数

(余数和被除数同号)你可能对结果0有疑问,你可以把它当成负0,因为被除数=除数*商+余数,所以被除数是希望商乘以除数的结果是接近它的(如最后一组数被除数2是希望-3乘以0后的结果是接近它的,所以可以理解为0是负0,这样就普遍适用了)
(3)
-3%-2=1…-1
-2%-3=0…-2
两个数都是负数:

先按正数计算,商正余负

(对于第二组可理解为0是正0,解释同上)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/139695.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • ScriptManager局部刷新「建议收藏」

    ScriptManager局部刷新「建议收藏」ScriptManager和UpdatePanel控件联合使用可以实现页面异步局部更新的效果。其中的UpdatePanel就是设置页面中异步局部更新区域,它必须依赖于ScriptManager存在,因为ScriptManger控件提供了客户端脚本生成与管理UpdatePanel的功能。几个重要的属性:ScriptManager控件的EnablePartialRendering属性:true…

  • 微软低代码平台_msfconsole下载

    微软低代码平台_msfconsole下载关于msfconsolemsfconsole简称msf是一款常用的渗透测试工具,包含了常见的漏洞利用模块和生成各种木马。是出家旅行的必备神器,今天我们在一起来回顾下吧。启动在终端执行servicepostgresqlstart#启动postgresql不启动也可以msfconsole常见的参数解读-p,–payload<payload>指定需要使用的payload(攻击…

  • 一些好玩的代码_100个简单代码

    一些好玩的代码_100个简单代码1.让网页的图片都漂动起来将以下代码复制到地址框,回车。有些浏览器会把"javaScript"过滤掉,可手动添加"javaScript"2.一行代码让电脑

  • Spring AOP实现原理简介[通俗易懂]

    Spring AOP实现原理简介[通俗易懂]AOP联盟标准AOP联盟将AOP体系分为三层,从三层结构可以看出,AOP实现方式有很多种,包括反射、元数据处理、程序处理、拦截器处理等,通过本节学习,你就会看到SpringAOP的实现使用的是Java语言本身的特性,即JavaProxy代理类、拦截器技术实现。AOP简介概念切面(Aspect):官方的抽象定义为“一个关注点的模块化,这个关注点可能会横切多个对象”。连接点(Joinpoint)…

  • 缓存穿透,缓存击穿,缓存雪崩解决方案分析[通俗易懂]

    缓存穿透,缓存击穿,缓存雪崩解决方案分析[通俗易懂]前言设计一个缓存系统,不得不要考虑的问题就是:缓存穿透、缓存击穿与失效时的雪崩效应。缓存穿透缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个存在的数据每次请求都要到存储层去查询,失去了缓存的意义。在流量大时,可能DB就挂掉了,要是有人利用不存在的key频繁攻击我们的应用,这就是漏洞。解决方案

  • c++ stl 优先队列_低优先级队列要等几局

    c++ stl 优先队列_低优先级队列要等几局priority_queue文章目录priority_queuepriority_queue的使用priority_queue在OJ中的使用数组中第k个最大元素priority_queue模拟实现push的模拟实现pop模拟实现迭代器区间构造函数模拟实现size的模拟实现empty的模拟实现top的模拟实现swap的模拟实现仿函数typename仿函数的变异玩法翻译:优先队列是一种容器适配器,根据严格的弱排序标准,它的第一个元素总是它所包含的元素中最大的。此上下文类似于堆,在堆中可以随时插入元

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号