二进制128位整数运算
2017-01-18 15:46
260 查看
GCC提供了两种128位整数类型,分别是__int128_t和__uint128_t,分别用于声明有符号整数变量和无符号整数变量。
有关GCC的文档参见:Using the GNU Compiler Collection (GCC)。
这里给出了样例程序,是有关类型__int128_t和__uint128_t的。从计算可以看出,这两个类型都是16字节的,类型__uint128_t是128位的。程序中使用了按位取反运算,移位运算和乘法运算。
由于这种大整数无法使用函数printf()输出其值,所以自己做了一个整数转字符串函数myitoa(),用于实现128位整数的输出。
编程操作系统是Ubuntu15.10,使用Qt编写程序,编译器是gcc的版本是5.2.1。
样例程序:
程序运行结果:
程序运行结果截图:
有关GCC的文档参见:Using the GNU Compiler Collection (GCC)。
这里给出了样例程序,是有关类型__int128_t和__uint128_t的。从计算可以看出,这两个类型都是16字节的,类型__uint128_t是128位的。程序中使用了按位取反运算,移位运算和乘法运算。
由于这种大整数无法使用函数printf()输出其值,所以自己做了一个整数转字符串函数myitoa(),用于实现128位整数的输出。
编程操作系统是Ubuntu15.10,使用Qt编写程序,编译器是gcc的版本是5.2.1。
样例程序:
#include <iostream> using namespace std; void myitoa(__int128_t v, char* s) { char temp; int i=0, j; while(v >0) { s[i++] = v % 10 + '0'; v /= 10; } s[i] = '\0'; j=0; i--; while(j < i) { temp = s[j]; s[j] = s[i]; s[i] = temp; j++; i--; } } int main() { __uint128_t n = 0; n = ~n; int count = 0; while(n > 0) { count++; n >>= 1; } cout << "count=" << count << endl; cout << "__uint128_t size=" << sizeof(__uint128_t) << endl; cout << endl; cout << "__int128_t size=" << sizeof(__int128_t) << endl; __int128_t x = 1100000000000000L; __int128_t y = 2200000000000000L; char s[40]; x *= y; myitoa(x, s); cout << "x=" << s << endl; return 0; }
程序运行结果:
count=128 __uint128_t size=16 __int128_t size=16 x=2420000000000000000000000000000
程序运行结果截图:
相关文章推荐
- 位运算之求整数二进制表示中1的个数
- 位运算笔试练习——判断两个整数(32位)的二进制表达有多少个位不同?
- 【大数算法】( 十进制整数四则运算) 十进制运算与二进制比较与思考
- 位运算--一个整数的二进制表示中1的个数
- 统计一个整数的二进制中1的个数(位运算技巧)
- 用移位运算实现一个整数二进制形式的输出--简短程序分析
- 位运算求解一个整数的二进制中1的个数
- 深入理解计算机系统(2.6)---二进制整数的乘、除法运算(重要)【困难度高】
- 位运算之统计一个整数的二进制中1的个数
- 位运算之统计一个整数的二进制中1的个数
- 二进制整数的加,减运算
- 深入理解计算机系统(2.5)---二进制整数的加、减法运算(重要)
- 统计一个整数的二进制中1的个数(位运算技巧)
- 28.整数的二进制表示中1的个数(运算)
- c#如何将一个整数转换二进制,并进行位运算
- 深入理解计算机系统(2.6)---二进制整数的乘、除法运算(重要)【困难度高】
- [转载] C++位运算:将一个4字节整数的二进制表示中的001替换为011
- c#如何将一个整数转换二进制,并进行位运算
- 位运算之求整数二进制的最低位1的权值
- 二进制整数的乘除运算