16进制的简单运算
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
- 描述
-
现在给你一个16进制的加减法的表达式,要求用8进制输出表达式的结果。
- 输入
-
第一行输入一个正整数T(0<T<100000)
接下来有T行,每行输入一个字符串s(长度小于15)字符串中有两个数和一个加号或者一个减号,且表达式合法并且所有运算的数都小于31位 - 输出
- 每个表达式输出占一行,输出表达式8进制的结果。
- 样例输入
-
3 29+4823 18be+6784 4ae1-3d6c
- 样例输出
-
44114 100102 6565
-
这题不能采用CIN COUT,否则就会超时,还是采用scanf,printf吧
查看代码---运行号:252210----结果:Accepted
运行时间:
2012-10-05 13:30:22 | 运行人:
huangyibiao
01.
#include <cstdio>
02.
using namespace std;
03.
04.
int main()
05.
{
06.
long firstNum,
07.
secondNum;
08.
char op;
09.
int t;
10.
11.
scanf("%d ", &t);
12.
while (t--)
13.
{
14.
scanf("%x%c%x", &firstNum, &op, &secondNum);
15.
if (op == '+')
16.
printf("%o\n", firstNum+secondNum);
17.
else
18.
printf("%o\n", firstNum-secondNum);
19.
}
20.
21.
return 0;
22.
}