十六进制的加法HDU2057

  http://acm.hdu.edu.cn/showproblem.php?pid=2057   

题目链接 借鉴了别人的

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

1.其实C中存在十六进制的输入输出(%X,%x)。所以这题可以直接用十六进制输入,然后进行十六进制的运算(其实不管是什么进制,在计算机中都是以二进制来计算的,只是按输入输出的格式不同,而强制转化为其它的进制),就像十进制的加法一样。这里要注意的是输入小于15位,结果超过了二进制中的32位而小于64位。所以这里用__int64的类型。输入输入出格式就是(%I64x,%I64X)由于%I64X,不能输出负数,所以负数的输出要做处理

在这里 你要明白的是 计算机存入的数据是二进制 0 1 

所以scanf("%d",&a);就是你输入的一个十进制 比如 你输入10(这边是十进制数) 他也代表10(十六进制) 计算机存储是

10000scanf("%x",&a);就是你输入的一个十六进制 比如 你输入10(是这边是十六进制数) 他也代表8(十进制) 计算机存储是 1000而在计算b=a/15-273 的时候 计算机是用它们各自表示的二进制来计算的

因此事实上得到的b存在计算机里是以二进制存在的 ,只是当你输出时候利用强制转换输出才变成我们想要的十进制或者十六进制 比如: 在b输出时候用十六进制输出 也就是printf("%x",b);

2.Int64是有符号 64 位整数数据类型,相当于C++中的long long、 C# 中的 long 和 SQL Server 中的 bigint,表示值介于 -2^63 ( -9,223,372,036,854,775,808) 到2^63-1(+9,223,372,036,854,775,807 )之间的整数。

#include<stdio.h>
int main()
{
__int64 j;
scanf("%I64d",&j);
printf("%I64d",j);
}
%x与%I64x的区别?
%x是按小写输出,既10-15输出是a-f
%X是按大写输出,既10-15输出是A-F

#include<stdio.h>
int main()
{
	__int64 a,b,sum;
	while(scanf("%I64x%I64x",&a,&b)!=EOF)
	{ 
		sum=a+b;
		if(sum >= 0){
            printf("%I64X\n",sum);
        }else{
            sum = -sum;
            printf("-%I64X\n",sum);
        }
	}
	return 0;
} 




  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是 C++ 实现 16 进制加法的示例代码: ```c++ #include <iostream> #include <string> using namespace std; string hex_add(string num1, string num2) { // 将两个字符串前面补 0,使它们的长度相等 int len = max(num1.length(), num2.length()); while (num1.length() < len) { num1 = "0" + num1; } while (num2.length() < len) { num2 = "0" + num2; } string result = ""; int carry = 0; for (int i = len - 1; i >= 0; i--) { int sum = carry; if (num1[i] >= '0' && num1[i] <= '9') { sum += num1[i] - '0'; } else { sum += num1[i] - 'A' + 10; } if (num2[i] >= '0' && num2[i] <= '9') { sum += num2[i] - '0'; } else { sum += num2[i] - 'A' + 10; } carry = sum / 16; sum %= 16; if (sum >= 0 && sum <= 9) { result = to_string(sum) + result; } else { result = (char)(sum - 10 + 'A') + result; } } if (carry > 0) { result = to_string(carry) + result; } return result; } int main() { string num1, num2; cout << "请输入两个 16 进制数:" << endl; cin >> num1 >> num2; string result = hex_add(num1, num2); cout << "它们的和为:" << result << endl; return 0; } ``` 在上面的代码中,我们定义了一个 `hex_add` 函数,用于实现 16 进制加法。该函数接受两个字符串类型的参数 `num1` 和 `num2`,分别表示需要相加的两个 16 进制数。在函数内部,我们首先将这两个字符串前面补 0,使它们的长度相等。接下来,我们从后往前遍历这两个字符串,并将它们对应位置上的字符转换成数字,然后将它们相加。如果相加的结果大于等于 16,则需要进位,并将相加的结果减去 16。最后,我们将得到的结果转换成字符,并将其存储到一个新的字符串 `result` 中。在遍历完这两个字符串后,如果还有进位,则需要将进位的值加上去。最后,我们返回结果字符串 `result`。 在 `main` 函数中,我们首先提示用户输入两个 16 进制数,然后调用 `hex_add` 函数计算它们的和,并输出结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Clark-dj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值