题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2057

曾记得自己用最原始的想法写过一次,找了N久,没找到,想是没写对或者忘交了……

再次接触时,发现有大牛曾这样做,让我感到鸭梨很大……

代码如下:

View Code
#include<stdio.h>
int main()
{
__int64 a,b;
while(scanf("%I64X%I64X",&a,&b)!=EOF)
{
printf(a+b<0?"-%I64X\n":"%I64X\n",a+b<0?-(a+b):a+b);

}
return 0;
}

解释如下:

题目求的是十六进制的加法。刚开始想的是把十六进制转化为十进制,进行加法运算后,再转化为十六进制。

所以这题可以直接用十六进制输入,然后进行十六进制的运算(其实不管是什么进制,在计算机中都是以二进制来计算的,只是按输入输出的格式不同,而强制转化为其它的进制),就像十进制的加法一样。

这里要注意的是输入小于15位,结果超过了二进制中的32位而小于64位。所以这里用__int64的类型。输入输入出格式就是(%I64x,%I64X)。由于%I64X,不能输出负数,所以负数的输出要做处理。

在这里 你要明白的是 计算机存入的数据是二进制 0 1  所以scanf("%d",&a);就是你输入的一个十进制比如 你输入10(这边是十进制数) 他也代表10(十六进制) 计算机存储是 10000
  scanf("%x",&a);就是你输入的一个十六进制 
  比如 你输入10(是这边是十六进制数) 他也代表8(十进制) 计算机存储是 1000
  而在计算b=a/15-273 的时候 计算机是用它们各自表示的二进制来计算的
  因此事实上得到的b存在计算机里是以二进制存在的 只是当你输出时候利用强制转换输出才变成我们想要的十进制或者十六进制 
  比如: 在b输出时候用十六进制输出 也就是printf("%x",b);

本想把出处写上,但看到作者本人也是抄袭过来,便未把链接附上。。。

posted on 2012-03-24 15:48  world_ding  阅读(1318)  评论(1编辑  收藏  举报