永发信息网

C语言 实现int128位+-*/ 别给我c++的什么类我不会c++

答案:5  悬赏:40  手机版
解决时间 2021-02-19 12:15
  • 提问者网友:我们很暧昧
  • 2021-02-19 01:01
如果 不给代码的话
就描述一下 如何实现 细致一点啊 我是小白啊 谢谢啦
最佳答案
  • 五星知识达人网友:轮獄道
  • 2021-02-19 01:37
有一个很神奇的类型是__int128这个可以应该可以实现你的想法,
讲道理的话,编译器的gcc是不支持__int128这种数据类型的,比如在codeblocks 16.01/Dev C++是无法编译的,但是提交到大部分OJ上是可以编译且能用的。C/C++标准。IO是不认识__int128这种数据类型的,因此要自己实现IO,其他的运算,与int没有什么不同。
但是官方上写了GCC提供了两种128位整数类型,分别是__int128_t和__uint128_t,分别用于声明有符号整数变量和无符号整数变量。
由于这种大整数无法使用函数printf()输出其值,所以自己做了一个整数转字符串函数write(),用于实现128位整数的输出。
亲测oj和洛谷可以AC
加法模板如下
#include <bits/stdc++.h>
using namespace std;
inline __int128 read()
{
    __int128 x=0,f=1;
    char ch=getchar();
    while(ch<'0'||ch>'9')
    {
        if(ch=='-')
            f=-1;
        ch=getchar();
    }
    while(ch>='0'&&ch<='9')
    {
        x=x*10+ch-'0';
        ch=getchar();
    }
    return x*f;
}

inline void write(__int128 x)
{
    if(x<0)
    {
        putchar('-');
        x=-x;
    }
    if(x>9)
        write(x/10);
    putchar(x%10+'0');
}

int main()
{
    __int128 a = read();
    __int128 b = read();
    write(a + b);
    return 0;
}
全部回答
  • 1楼网友:琴狂剑也妄
  • 2021-02-19 06:49
如果你有耐心的话,可以尝试用数组实现加减乘除运算,这样可以保证很大程度上的精度
  • 2楼网友:老鼠爱大米
  • 2021-02-19 05:13
1、在C语言中,并没有任何数据类型可以表示精确的128位数。所以要表示128位数,就必须用数组模拟。比如,用字符数组模拟,每位字符表示一位数,使用'0'~'9'表示各个位上的数值。 2、例如 char num[129] = "12345678"; 表示数字12345678。 由于128位过长,就不举128位的例子了。 输入输出均可以用字符串的方式。 另外,做计算的话,就必须自己写函数了,如加减乘除模除等,对于这类实现,在算法中称为大数计算,如果需要,可以对此进行搜索,有很多优秀算法。
  • 3楼网友:渡鹤影
  • 2021-02-19 04:28
其实就是把你自己列竖式计算四则运算的过程翻译成代码就好。效率低一点的话就把10进制的每一位数码弄成一个int,然后按照竖式运算来计算;效率高一点就把一个unsigned int看成一位数码,整个整数看做“4294967296进制”,运算道理一样
  • 4楼网友:忘川信使
  • 2021-02-19 03:05
18
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯