C/C++ __int128的使用

__int128在gcc、codeblocks、vs2017都是不被支持的,不过__int128在Linux上可以编译并且能用。

我们提交到大部分OJ上都是可以编译且能用的。

输入输出
C/C++标准IO是不认识__int128这种数据类型的,cin和cout是无法输出__int128的,所以我们要自己实现输入输出,其他的运算,与int没有什么不同。

可以对long long直接强转成__int128
__int128能直接做加减乘除赋值

这里贴一份输入输出外挂的(kuangbin)模板
代码

#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 print(__int128 x){
    if(x < 0){
        putchar('-');
        x = -x;
    }
    if(x > 9)
        print(x / 10);
    putchar(x % 10 + '0');
}
int main(void){
    __int128 a = read();
    __int128 b = read();
    print(a + b);
    cout << endl;
    return 0;
}

代码2

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
__int128 read();
void write(__int128 x);
int main(){
    __int128 num = read();
    num *= 2;//可以直接做加减乘除的操作
    write(num);
    return 0;
}
__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;
}
void write(__int128 x){
    if(x < 0){
        putchar('-');
        x = -x;
    }
    if(x > 9)
        write(x / 10);
    putchar(x % 10 + '0');
}

参考来源

博客
https://blog.csdn.net/shadandeajian/article/details/81843805
博客
https://blog.csdn.net/tianwei0822/article/details/80687466

### 使用 `__int128` 数据类型在 Dev-C++ 中 #### 编译器支持情况 Dev-C++ 默认使用的 TDM-GCC 或 MinGW 编译器版本可能不完全支持 `__int128` 类型。具体来说,在某些旧版编译器中确实存在对这一扩展数据类型的缺失支持[^1]。 然而,现代 GCC 版本已经引入了对于 `__int128` 的良好兼容性。如果希望利用该特性,则建议更新至最新稳定发行版的 TDM-GCC 或者 MinGW-w64 编译链工具集,并确认其版本号不低于能够识别并处理此类大整数的能力。 #### 声明与基本操作方法 一旦确保所用编译环境适当,就可以像下面这样定义变量: ```cpp #include <iostream> // 定义无符号和带符号形式的 128 位整数 typedef unsigned __int128 uint128; typedef __int128 sint128; void print_uint128(const uint128& value){ std::cout << "Value as string: "; // 手动实现打印逻辑... } int main(){ uint128 a = 170141183460469231731687303715884105727ULL; // 构造一个较大的正数 sint128 b = -a; // 赋予负值 // 输出测试(需自定义函数) print_uint128(a); return 0; } ``` 需要注意的是,默认的标准库输入输出流并不直接支持这些非常规的数据结构,所以当涉及到显示或读取这类数值时往往需要额外编写辅助程序来完成相应的转换工作。 #### 输入输出解决方案 由于 C/C++ 标准 I/O 流无法原生解析 `__int128` ,故而应当采取如下措施之一来进行有效的交互: - 实现专门针对此类型的字符串化算法; - 利用第三方库提供更高级别的抽象接口; - 将 `__int128` 分解成较小部分再分别处理。 例如,可以通过逐字节提取的方式将其转化为十六进制表示法以便于可视化展示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值