Tim*_*Tim 19

浮点除法然后转换为int.无需额外的模块.

>>> int(float(-1)/2)
0
>>> int(float(-3)/2)
-1
>>> int(float(1)/2)
0
>>> int(float(3)/2)
1
Run Code Online (Sandbox Code Playgroud)

  • 在某些邪恶的情况下,这个答案可能是错误的。Python 中的除法遵循 IEEE,使用“舍入到最接近的偶数”舍入模式,因此在某些情况下除法可能会关闭。 (2认同)

jji*_*now 7

当有一个完美的 math.trunc() 函数时,为什么要重新发明轮子呢?

import math
print(math.trunc(-3.5))
>>-3
print(math.trunc(3.5))
>>3
Run Code Online (Sandbox Code Playgroud)


Mar*_*son 6

对于它的价值,我自己最喜欢的解决方案是这个。仅整数算术,单除法,以及其他所有线性时间:

def integer_divide_towards_zero(a, b):
    return -(-a // b) if a < 0 else a // b
Run Code Online (Sandbox Code Playgroud)

假设这b是肯定的,但在我见过的大多数应用程序中都是如此。如果你也需要处理负数b,那么函数会稍微复杂一些:

def integer_divide_towards_zero(a, b):
    return -(-a // b) if (a < 0) ^ (b < 0) else a // b
Run Code Online (Sandbox Code Playgroud)

一些示例输出:

>>> integer_divide_towards_zero(11, 3)
3
>>> integer_divide_towards_zero(-11, 3)
-3
>>> integer_divide_towards_zero(6, 3)
2
>>> integer_divide_towards_zero(-6, 3)
-2
>>> integer_divide_towards_zero(11, -3)
-3
>>> integer_divide_towards_zero(-11, -3)
3
Run Code Online (Sandbox Code Playgroud)


daw*_*awg 5

Python的默认整数除法返回底线(朝向负无穷大),无法改变它.你可以阅读 BDFL的原因.

要做'向上'分工,你会使用:

>>> a=1
>>> b=2
>>> (a+(-a%b))//b
1
>>> a,b=-1,2
>>> (a+(-a%b))//b
0
Run Code Online (Sandbox Code Playgroud)

要向零截断并保持整数除法,(a+(-a%b))//b如果a或b为负,则使用,如果两者均为正,则使用默认除法.

这将进行整数除法并始终向零舍入:

>>> a=1
>>> b=2
>>> a//b if a*b>0 else (a+(-a%b))//b
0
>>> a=-1
>>> b=2
>>> a//b if a*b>0 else (a+(-a%b))//b
0
>>> a,b=-3,2
>>> a//b if a*b>0 else (a+(-a%b))//b
-1
>>> a,b=3,2
>>> a//b if a*b>0 else (a+(-a%b))//b
1
Run Code Online (Sandbox Code Playgroud)

脚注

有趣的是,C99声明向零舍入是默认值:

#include <stdio.h>
int main(int argc, const char * argv[])
{

    int a=-3;
    int b=2;
    printf("a=%d, b=%d, a/b=%d\n",a,b,a/b);
    a=3;
    printf("a=%d, b=%d, a/b=%d\n",a,b,a/b);
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

打印:

a=-3, b=2, a/b=-1
a=3, b=2, a/b=1
Run Code Online (Sandbox Code Playgroud)