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.
}