64位除法

时间:2008-12-14 07:39:09

标签: c algorithm 64-bit

任何人都可以给我发一个C代码来分割2个64位数字。我的编译器只支持32/32分区。

Thanx&此致

摩尼

5 个答案:

答案 0 :(得分:11)

您是否肯定您的编译器不支持64位除法?如果你的C编译器支持C99,这应该可以工作:

#include <stdint.h>
#include <stdio.h>
int main(void)
{
    int64_t numerator = 123;
    int64_t denominator = 10;
    int64_t quotient = numerator / denominator
    printf("%" PRId64 " / %" PRId64 " = %" PRId64 "\n",
           numerator, denominator, quotient);
    return 0;
}

答案 1 :(得分:6)

该代码在linux中可用,请参阅div64.c。你能复制一下吗?

答案 2 :(得分:4)

更一般的想法是使用多精度库,如GMP

  

GMP是一个免费的库,用于任意精度算术,对有符号整数,有理数和浮点数进行操作。精度没有实际限制,除了机器GMP中可用内存所暗示的那些限制。 GMP具有丰富的功能,并且功能具有常规接口。

使用void mpf_div (mpf_t rop, mpf_t op1, mpf_t op2)

处理浮点除法

答案 3 :(得分:1)

在Linux内核中寻找其他地方:udivdi3.c

这应该准确地提供GCC在遇到64位除法时使用的函数。

答案 4 :(得分:1)

很可能,除法限制源于你正在编译32位而不是64位的事实。

我不记得看到为x86处理64位的整数除法指令。它将乘以2个32位整数,并将结果分成2个寄存器,但不记在我的记忆中。