免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 17007 | 回复: 4
打印 上一主题 下一主题

负数取模的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-09 12:26 |只看该作者 |倒序浏览
这两天写了个程序,其中有用到取模的操作

一直以来, 我都默认:

-n mod m = (m-n) mod m
也就是:  -3 mod 12 = (12-3) mod 12 = 9

不过程序的结果并不是这样, 而是出来一个非常奇怪的结果, 于是分别用微软的计算器和google的计算器算了下:
微软计算器:    -3 mod 12 = -3
google计算器:  -3 mod 12 = 9

网上查了下,负数取模似乎和编译器有关. 所以, 如果我们的程序中如果有对负数取模时, 应该显示的转换成正数再求,
否则可能得到意想不到的结果.

论坛徽章:
0
2 [报告]
发表于 2008-12-09 12:43 |只看该作者
对负数取模。。。应该没有相关的规范吧

论坛徽章:
0
3 [报告]
发表于 2008-12-09 13:26 |只看该作者
负数取模是实现相关的,标准没有规定。

论坛徽章:
0
4 [报告]
发表于 2008-12-09 13:38 |只看该作者

回复 #4 cugb_cat 的帖子

呵呵, 是啊, 调程序的时候没有意识到, 所以搞得很郁闷
发出来, 是希望兄弟们下次碰到这个问题,能够少走弯路

论坛徽章:
4
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11IT运维版块每日发帖之星
日期:2016-08-11 06:20:00IT运维版块每日发帖之星
日期:2016-08-15 06:20:00
5 [报告]
发表于 2008-12-09 13:42 |只看该作者

回复 #1 drowsyboy 的帖子

我这两天刚好也碰到了这样的问题。
在Linux环境下,对负数求模,结果也是负数!
我的解决方法:转换为无符号整数,然后求模。
例如:
index = ((unsigned int)n) % m;
m是一个数值有限的正整数(如:10)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP