总结:
①不管是什么进制,在计算机中都是以二进制来计算的,只是按输入输出的格式不同,而强制转化为其它的进制
②这里要注意的是15位的16进制数超过了二进制中的32位而小于64位。所以这里用__int64的类型。输入输入出格式就是(%I64x,%I64X)。
③由于%I64X,不能输出负数,所以负数的输出要做处理。
④在这里 要明白的是 计算机存入的数据是二进制 0 1 所以scanf("%d",&a);就是你输入的一个十进制 比如 你输入10(这边是十进制数) 他也代表10(十六进制) 计算机存储是 10000
scanf("%x",&a);就是你输入的一个十六进制 比如 你输入10(十六进制数)他也代表8(十进制) 计算机存储是 1000
而在计算的时候 计算机是用它们各自表示的二进制来计算的 因此事实上得到的b存在计算机里是以二进制存在的 只是当你输出时候利用强制转换输出才变成我们想要的十进制或者十六进制
比如: 在b输出时候用十六进制输出 也就是printf("%x",b);
#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
long long A, B;
//__int64 A, B;
while(scanf("%llX%llX",&A, &B)!=EOF)
{
long long sum=A+B;
if(sum<0){
cout<<'-';
sum=-sum;
}
printf("%llX\n", sum);
//printf("%I64X\n", sum);
}
return 0;
}