取余和取模的区别

通常取模运算也叫取余运算,它们返回结果都是余数 .rem 和 mod 唯一的区别在于:

当 x 和 y 的正负号一样的时候,两个函数结果是等同的;当 x 和 y 的符号不同时,rem 函数结果的符号和 x 的一样,而 mod 和 y 一样。

这是由于这两个函数的生成机制不同,rem 函数采用 fix 函数,而 mod 函数采用了 floor 函数(这两个函数是用来取整的,fix 函数向 0 方向舍入,floor 函数向无穷小方向舍入)。 rem(x,y)命令返回的是 x-n.*y,如果 y 不等于 0,其中的 n = fix(x./y),而 mod(x,y) 返回的是 x-n.*y,当 y 不等于 0 时,n=floor(x./y)

两个异号整数取模取值规律 (当是小数时也是这个运算规律,这一点好像与 C 语言的不太一样)

先将两个整数看作是正数,再作除法运算:

  • 1、能整除时,其值为 0
  • 2、不能整除时,其值=除数×(整商+1)-被除数

例:mod(36,-10)=-4

即:36 除以 10 的整数商为 3,加 1 后为 4;其与除数之积为 40;再与被数之差为(40-36=4);取除数的符号。所以值为 -4。

例:mod(9,1.2)=0.6;

例:

>> mod(5,2)
ans =1                   % 除数是正,余数就是正
>> mod(-5,2)
ans =1
>> mod(5,-2)
ans =-1                  % 除数是负,余数就是负
>> mod(-5,-2)
ans =-1                  % 用 rem 时,不管除数是正是负,余数的符号与被除数的符号相同
>> rem(5,2)
ans =1                   % 被除数是正,余数就是正
>> rem(5,-2); 
ans =1
>> rem(-5,2)
ans =-1                 % 被除数是负, 余数就是负
>> rem(-5,-2)
ans =-1

对于整数 a,b 来说,取模运算或者求余运算的方法要分如下两步:

  • 1、求整数商:c=a/b
  • 2、计算模或者余数:r=a-(c*b)

求模运算和求余运算在第一步不同

取余运算在计算商值向0方向舍弃小数位

取模运算在计算商值向负无穷方向舍弃小数位

例如:4/(-3) 约等于 -1.3

在取余运算时候商值向 0 方向舍弃小数位为 -1

在取模运算时商值向负无穷方向舍弃小数位为-2

所以

4rem(-3)=1
4mod(-3)=-2

1.取模运算多见于计算机领域,取余运算一般用于数学领域。

2.取模运算(取余运算)计算步骤

a、求整数商

c=a/b

b、求模(余数)

r=a-c*b

3.两者不同点:取模运算 c 向负无穷远处取整,取余运算 c 向 0 方向取整。

4.结论:a 为正整数时,取模运算和取余运算结果相同;a 为负整数时,两者结果不同。

### 取余、取整与取模的概念及区别 #### 取余 取余操作,又称模运算(modulus operation),是一种数学运算,用于找出除法运算中的余数。其形式通常表示为“%”,即当有表达式 `a % b` 时,b 称为模数,而 a/b 的商的部分忽略不计,仅关注余数。举个例子,`7 % 3` 结果为 `1`,因为 7 除以 3 后的余数为 1。 #### 取整 取整操作旨在将一个数值调整至最接近的一个特定类型的数值(通常是整数),使得该数值不超过原始值的最大取整。主要有以下几种常见的取整方式: - **向上取整**(Ceiling):无论数字的小数部分是多少,总是将其增加到下一个整数。比如 `ceil(3.2)` 结果为 `4`。 - **向下取整**(Floor):不管数字的小数部分,总是减少到前一个整数。比如 `floor(3.8)` 结果为 `3`。 - **四舍五入**:对于正数来说,如果小数部分超过0.5,则向较大整数取整;若小于0.5,则向较小的整数取整。对于负数而言,同样的原则应用,只是考虑到负数的情况。比如 `round(3.5)` 结果为 `4`,`round(-3.5)` 结果为 `-4`。 #### 取模 取模取余非常相似,实际上在很多上下文中它们可以互换使用。取模操作也是指获取两数相除后的余数,常用于数学、算法和程序设计中,特别是在对数组下标进行循环索引时防止溢出。 ### 实际应用场景 1. **时间周期问题**:在日历和时间管理的应用中,计算每过一定周期的时间点(如每小时、每天等); 2. **数组循环**:在遍历数组元素时使用模运算作为索引,以实现在数组长度范围内循环访问元素; 3. **密码学**:在加密算法中经常需要用到模运算来保证数据的范围处于某一特定区间内,如RSA加密算法中的运算。 理解这三者的准确含义及其差异可以帮助在编程中更有效地解决问题,并在各种数学和逻辑应用场合中灵活运用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值