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
这个题我有两个个原因要发,第一个是,我忘记了十六进制,八进制如何输入输出的了,这个题刚好让我复习了一下。还有就是,这个题符号的处理很巧妙。判断一下。我一开始一直想不到如何去实施。
#include<stdio.h>
#include<string.h>
#include<math.h>
int main()
{
int n;
int i, j, t;
int a[105];
scanf("%d",&t);
while(t--)
{
int a, b;
char c;
scanf("%x%c%x",&a,&c,&b);
if(c=='+')
printf("%o\n",a+b);
else printf("%o\n",a-b);
}
return 0;
}