- 在线时间
- 57 小时
- 最后登录
- 2013-10-20
- 注册时间
- 2012-3-19
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 1080 点
- 威望
- 0 点
- 阅读权限
- 40
- 积分
- 433
- 相册
- 0
- 日志
- 0
- 记录
- 7
- 帖子
- 196
- 主题
- 13
- 精华
- 0
- 分享
- 82
- 好友
- 20
升级   44.33% TA的每日心情 | 开心 2013-10-20 20:29 |
|---|
签到天数: 103 天 [LV.6]常住居民II
- 自我介绍
- 建模编程方向
 群组: 学术交流A |
取模(mod)与取余(rem)的区别——Matlab学习笔记【09-11-15】4 k6 U' d; c; T4 [/ w% w
本帖来自:数学中国 作者: 木长春 日期: 2009-11-15 19:51 您是本帖第535个浏览者
' `% [- f7 P' l- x7 x, i$ ~昨天在学习Matlab的数学函数时,教程中提到取模(mod)与取余(rem)是不同的,今天在网上具体查了一下:0 A. B; q) V! ]* y! }, M; a+ ?2 O" d+ W
! c' D: _& E, H; a2 I- a
通常取模运算也叫取余运算,它们返回结果都是余数.rem和mod唯一的区别在于:
6 r2 o1 I% m" M/ T- |; V 当x和y的正负号一样的时候,两个函数结果是等同的;当x和y的符号不同时,rem函数结果的符号和x的一样,而mod和y一样。, B4 n- ?% v; c' ~# Y
这是由于这两个函数的生成机制不同,rem函数采用fix函数,而mod函数采用了floor函数(这两个函数是用来取整的,fix函数向0方向舍入,floor函数向无穷小方向舍入)。
3 q, {) x- _, p' L# ~8 A Y1 @: r rem(x,y)命令返回的是x-n.*y,如果y不等于0,其中的n = fix(x./y),而mod(x,y)返回的是x-n.*y,当y不等于0时,n=floor(x./y)6 N9 G3 S" t* O0 \: r L- a- }
, y1 r/ ]) }. F* {! Z6 m
' b% V8 o8 }# k! X# M F% {- a两个异号整数取模取值规律 (当是小数时也是这个运算规律,这一点好像与C语言的不太一样)
- S: z/ C7 O4 ?' s
, G" N& r. k9 ?5 K7 w$ p先将两个整数看作是正数,再作除法运算* j5 Y. g( ]: T' C& q
①能整除时,其值为08 p# m1 u( W! R/ \1 ?" W' H+ g
②不能整除时,其值=除数×(整商+1)-被除数5 g( R) f1 _1 U5 K
4 C) B3 t; ^. l7 ?0 L0 X
例:mod(36,-10)=-4
& k) G# ^3 H" a9 m P* A- r M即:36除以10的整数商为3,加1后为4;其与除数之积为40;再与被数之差为(40-36=4);取除数的符号。所以值为-4。
: D7 ~* y( c1 s: q7 u例:mod(9,1.2)=0.68 E8 V6 S% O$ U( ~! {( f! l
例:
4 |0 e$ U* T6 O U( K3 u6 G/ u3 k>> mod(5,2)
2 R; h7 o# p. {& R: ^: Fans =1 %“除数”是正,“余数”就是正
3 D9 Y. L) [9 U, g7 @, f5 o: D>> mod(-5,2)
3 R. H/ L8 I7 U" \; e, ?) {' n$ d. B1 Sans =1% V% a* L; r7 \, Z- b$ I
>> mod(5,-2)
/ e3 ^3 \, B9 [" y$ I# W4 f" `ans =-1 %“除数”是负,“余数‘就是负
8 ^ N1 B, V& \" y* O2 B>> mod(-5,-2)
, O3 N, Y: [ [/ | ^, ]7 Rans =-1 %用rem时,不管“除数”是正是负,“余数”的符号与“被除数”的符号相同# q C0 w8 x* t& a5 g2 d/ I" ~
>> rem(5,2)& l* C# `3 F8 k
ans =1 %“被除数”是正,“余数”就是正
" a4 D4 f. P% G2 c# L>> rem(5,-2)/ ^' P# G0 l2 @
ans =19 l) g! v$ x4 M1 K- ?( U
>> rem(-5,2); b4 C% Y& A" j: l' V$ P7 ^# N( }
ans =-1 %“被除数”是负,“余数”就是负1 ?8 F6 k+ ~0 L$ W0 y* L# X
>> rem(-5,-2)/ {0 S- @* i0 v) B* ]
ans =-18 N9 n4 i' u, t9 H/ `1 i' a
9 e C6 a4 C% L7 R) m5 C! z
- w5 s& e0 L( i' F" F$ \0 }- Z" Q慢慢体会,两者确实不一样
0 B/ {+ m6 x& w, R7 R2 ~ |
zan
|