博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu2057
阅读量:5115 次
发布时间:2019-06-13

本文共 905 字,大约阅读时间需要 3 分钟。

都是基础知识!

看了一位dn的解释,借鉴了:

题目求的是十六进制的加法。刚开始想的是把十六进制转化为十进制,进行加法运算后,再
转化为十六进制。后来发现自己忘了C中存在十六进制的输入输出(%X,%x)。所以这题可
以直接用十六进制输入,然后进行十六进制的运算(其实不管是什么进制,在计算机中都是
以二进制来计算的,只是按输入输出的格式不同,而强制转化为其它的进制),就像十进制的
加法一样。这里要注意的是输入小于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);

ContractedBlock.gif
ExpandedBlockStart.gif
View Code
 
#include
<
iostream
>
using
namespace
std;
int
main()
{
__int64 a,b,c;
int
i;
while
(scanf(
"
%I64X %I64X
"
,
&
a,
&
b)
!=
EOF)
{
c
=
a
+
b;
if
(c
<
0
){ cout
<<
"
-
"
; c
=-
c;}
printf(
"
%I64X\n
"
,c);
}
return
0
;
}

转载于:https://www.cnblogs.com/FCWORLD/archive/2011/05/13/2045840.html

你可能感兴趣的文章
《QQ欢乐斗地主》山寨版
查看>>
文件流的使用以及序列化和反序列化的方法使用
查看>>
Android-多线程AsyncTask
查看>>
第一个Spring冲刺周期团队进展报告
查看>>
红黑树 c++ 实现
查看>>
Android 获取网络链接类型
查看>>
linux中启动与终止lnmp的脚本
查看>>
gdb中信号的处理[转]
查看>>
LeetCode【709. 转换成小写字母】
查看>>
如何在Access2007中使用日期类型查询数据
查看>>
Jzoj4757 树上摩托
查看>>
CF992E Nastya and King-Shamans(线段树二分+思维)
查看>>
第一个Java Web程序
查看>>
树状数组_一维
查看>>
如果没有按照正常的先装iis后装.net的顺序,可以使用此命令重新注册一下:
查看>>
linux install ftp server
查看>>
嵌入式软件设计第8次实验报告
查看>>
算法和数据结构(三)
查看>>
Ubuntu下的eclipse安装subclipse遇到没有javahl的问题...(2天解决了)
查看>>
alter database databasename set single_user with rollback IMMEDIATE 不成功问题
查看>>