第一个数小于第二个数时的模除法

Posted

技术标签:

【中文标题】第一个数小于第二个数时的模除法【英文标题】:Modulus division when first number is smaller than second number 【发布时间】:2013-04-25 01:36:27 【问题描述】:

如果这是一个简单的问题,我深表歉意,但是当第一个数字小于第二个数字时,我无法理解模除的概念。例如,当 1 % 4 我的书说余数是 1。我不明白 1 如何是 1 % 4 的余数。 1 / 4 是 0.25。我是否在错误地考虑模数除法?

【问题讨论】:

【参考方案1】:

首先,在 Java 中,% 是余数(不是取模)运算符,其语义略有不同。 也就是说,您需要考虑仅整数除法,就好像没有小数值一样。可以将其视为存储不可分割的项目:您可以在总容量为 1 的存储中存储零个大小为 4 的项目。存储最大项目数后您的剩余容量为 1。同样,13%5 是 3,因为您可以在 13 大小的存储中容纳 2 个大小为 5 的完整物品,剩余容量为13 - 2*5 = 3

【讨论】:

当第一个数字大于第二个数字时,我理解余数除法。所以我知道 13 % 5 是 3。我不明白的是,如果 5 % 13 时答案会是什么。 也叫模算子! @Ravi:这不是真的,模数和余数之间存在差异(例如blogs.msdn.com/b/ericlippert/archive/2011/12/05/…)。如果为负值,它会影响结果的符号是否跟随被除数或除数。 Javas % 操作符实现了余数语义。 @Ravi 你肯定错了(如果你拿Oracle作为参考),检查docs.oracle.com/javase/tutorial/java/nutsandbolts/op1.html @misberner,嗯,所以它不是官方术语。感谢您的参考。【参考方案2】:

如果将 1 除以 4,则得到 0,余数为 1。这就是模数,除法后的余数。

【讨论】:

如果是40%160会怎样 @yanivx 同样的事情,0 余数 40,所以答案是 40【参考方案3】:

我将为“Jean-Bernard Pellerin”已经说过的内容添加一个更实际的例子。

正确的是,如果你将 1 除以 4 得到 0,但是,为什么当你做 1 % 4 时你得到 1 作为结果?

基本上是因为:

n = a / b (integer), and
m = a % b = a - ( b * n )

所以,

 a    b    n = a/b  b * n  m = a%b
 1    4      0        0      1    
 2    4      0        0      2
 3    4      0        0      3
 4    4      1        0      0
 5    4      1        4      1

结论:当a

【讨论】:

"虽然 a 【参考方案4】:

另一种将其视为您的数字以另一个数字的倍数表示的方式。即a = n*b + r,其中b>r>=0。从这个意义上说,您的案例给出了1 = 0*4 + 1。 (编辑:只讨论正数)

【讨论】:

【参考方案5】:

我认为您对 %(Remainder)/(Division) 运算符感到困惑。

当你说% 时,你需要不断地除以除数,直到你得到余数 0 或可能的结尾。而你最终得到的是Remainder

当你说/时,你将除数除以直到除数变为1。你得到的最终产品称为Quotient

【讨论】:

【参考方案6】:

另一种清理问题的好方法, 在模数中,如果第一个数大于第二个数,则从第一个数中减去第二个数,直到第一个数小于第二个数。

17 % 5 = ?
17 - 5 = 12
12 % 5 = ?
12 - 5 = 7
7 % 5 = ?
7 - 5 = 2
2 % 5  = 2

因此 17 % 5、12 % 5、7 % 5 都给出 2 的答案。 这是因为 2 / 5 = 0(使用整数时)余数为 2。

【讨论】:

以上是关于第一个数小于第二个数时的模除法的主要内容,如果未能解决你的问题,请参考以下文章

POJ_3663_贪心

java冒泡排序详细讲解

C语言中,怎么比较三个数的大小??

康拓展开模板

2018final复数求模的类模板

冒泡排序