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
本想拿这道题练一下进制转换的,看完最优代码才知道c语言有直接的十六进制,八进制占位符
我的代码#include <iostream> #include <cstdio> using namespace std; int hd(char c) { if(c >= 'a') return c-'a'+10; else return c-'0'; } int main() { int n; char c; scanf("%d",&n); getchar(); while(n--) { int a = 0, b = 0, d = 0,sign = -1; while(1) { //a进制转10进制的核心就是d=x*a^n+y*a^n-1+………………+z*a^0 scanf("%c",&c); if(c == '+' || c =='-') break; a = a*16 + hd(c); } if(c == '+') sign = 1; else sign = 0; while(1) { scanf("%c",&c); if(c == '\n') break; b = b*16 + hd(c); } if(sign) d = a + b; else d = a - b; printf("%o\n",d); } }
最优代码:
01.#include<stdio.h> 02.int main() 03.{ 04.int T; 05.scanf("%d",&T); 06.while(T--) 07.{ 08.int a,b,d; 09.char c; 10.scanf("%x%c%x",&a,&c,&b); 11.if(c=='+') d=a+b; 12.else d=a-b; 13.if(d>=0) 14.printf("%o\n",d); 15.else printf("-%o\n",-d); 16.} 17.}