c和c++关于负数取模的问题
来源:互联网 发布:网络知识基础笔试 编辑:程序博客网 时间:2024/04/28 15:24
在不同的语言中,对负数执行取模运算,结果有可能会是不同的。例如,(-11)%5在python中计算的结果是4,而在C(C99)中计算的结果则是-1。
truncate除法 && floor除法
在大多数编程语言中,如果整数a不是整数b的整数倍数的话,那么a、b做除法产生的实际结果的小数部分将会被截除,这个过程称为截尾(truncation)。如果除法的结果是正数的话,那么一般的编程语言都会把结果趋零截尾,也就是说,直接把商的小数部分去除。但是如果除法的结果是负数的话,不同的语言通常采用了两种不同的截尾方法:一种是趋零截尾(truncate toward zero),另一种是趋负无穷截尾(truncate toward negative infinity);相应的,两种除法分别被称为truncate除法和floor除法。
事实上,可以认为不管除法的结果是正是负,truncate除法都是趋零结尾;而floor除法都是趋负无穷结尾。
取模运算
取模运算实际上是计算两数相除以后的余数。假设q是a、b相除产生的商(quotient),r是相应的余数(remainder),那么在几乎所有的计算系统中,都满足a=b*q+r,其中|r|<|a|。因此r有两个选择,一个为正,一个为负;相应的,q也有两个选择。如果a、b都是正数的话,那么一般的编程语言中,r为正数;或者如果a、b都是负数的话,一般r为负数。但是如果a、b一正一负的话,不同的语言则会根据除法的不同结果而使得r的结果也不同,并且一般r的计算方法都会满足r=a-(a/b)*b。
常见语言
(1)C/Java语言
C/Java语言除法采用的是趋零截尾(事实上,C89对于除数或被除数之一为负数情况的结果是未定义的;C99才正式确定了趋零截尾),即truncate除法。它们的取模运算符是%,并且此运算符只接受整型操作数。一个规律是,取模运算的结果的符号与第一个操作数的符号相同(或为0)。因此(-11)%5=-11-[(-11)/5]*5=-11-(-2)*5=-1。注意因为有复数所以,防止发生出现负数的结果,以(a % max +max)%max的形式输出保证为正!
(2)C++语言
C++语言的截尾方式取决于特定的机器。如果两个操作数均为正,那么取模运算的结果也为正数(或为0);如果两个操作数均为负数,那么取模运算的结果为负数(或为0);如果只有一个操作数为负数,那么取模运算的结果是取决于特定实现的。
- c和c++关于负数取模的问题
- 关于负数取模的问题
- 负数的除法和取模运算(Python 2.7和C的比较)
- Python中负数的除法和取模运算(和C比较)
- 《c陷阱与缺陷》笔记--负数的取模运算
- 《c陷阱与缺陷》笔记--负数的取模运算
- C++/Java负数取余(模)
- 关于负数取模
- php取模为负数的问题
- 关于C语言中负数的移位
- 关于求余和取模的区别以及负数取摸
- 负数的除法和取模运算
- C语言如何取一个数的负数
- C语言基础 有负数参与的取余运算
- C/C++除法实现方式及负数取模详解
- C/C++除法实现方式及负数取模详解
- C/C++除法实现方式及负数取模详解
- C/C++除法实现方式及负数取模详解
- ural 1917. Titan Ruins: Deadly Accuracy(Titan Ruins系列)
- oracle 几个用户的默认密码及修改
- ural 1915. Titan Ruins: Reconstruction of Bygones
- Linux(ubnutu)下编写运行c,c++程序的方法gcc+gdb+make(图示)
- vi常用命令
- c和c++关于负数取模的问题
- freopen()函数
- STL学习之priority_queue适配器
- STL<algorithm> sort函数详解(转)
- hdu 1233 还是畅通工程(最小生成树的Prim和Kruskal两种算法的c++实现)(prim算法详解)
- 位运算(转自matrix67)
- void main()是错的!
- sizeof运算符详解
- c,c++产生随机数详解