输入一个以#结束的字符串,要求滤去所有的非十二进制字符(不分大小写),组成一个新的表示十二进制数字的字符串,然后将其转换为十进制数后输出。题目保证输出在长整型范围内。
输入格式:
输入在一行中给出一个以#结束的非空字符串。
输出格式:
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
输入样例:
+P-xf1+a-4!B#
输出样例:
3227
解题过程
可参考L1-3【例7-14】【使用字符数组】 十六进制字符串转换成十进制非负整数-CSDN博客
#define _CRT_SECURE_NO_WARNINGS
#include <math.h>
#include <stdio.h>
#include <string.h>
int main() {
int s[114];
char c;
int q, t;
int n;
int m = 0;
for (;;) {
c = getchar();
if (c == '#')
break;
if (c >= '0' && c <= '9')
m = m * 12 + c - '0';
if (c >= 'a' && c <= 'b')
m = m * 12 + 10 + c - 'a';
if(c >= 'A' && c <= 'B')
m = m * 12 + 10 + c - 'A';
}
/*for (int i = 0;m != 0; i++) {
s[i] = m % t;
n = i;
m = m / t;
}
for (int i = n; i >= 0; i--) {
printf("%d", s[i]);
}*/
printf("%d", m);
}