7-15 十六进制字符串转换成十进制非负整数
分数 5
全屏浏览
切换布局
作者 颜晖
单位 浙大城市学院
输入一个以#结束的字符串,滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,输出该字符串并将其转换为十进制数后输出。
输入格式:
输入在一行中给出一个不超过80个字符长度的、以#结束的非空字符串。
输出格式:
第1行中输出已滤去所有非十六进制字符的字符串。
在第2行中输出转换后的十进制数。题目保证输出结果在长整型范围内。
输入样例:
-zy1+Ak0-bq?#
输出样例:
1A0b
6667
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
栈限制
8192 KB
#include <stdio.h>
int main(void)
{
int n,i,re=0;
char c[81]={0};
while(1){
c[n]=getchar();
if(c[n]=='#'){
break;
}
n++;
}
for(i=0;i<n;i++){
if(c[i]>='0'&&c[i]<='9'){
printf("%c",c[i]);
re=re*16+c[i]-'0';
}else if(c[i]>='a'&&c[i]<='f'){
printf("%c",c[i]);
re=re*16+c[i]+10-'a';
}else if(c[i]>='A'&&c[i]<='F'){
printf("%c",c[i]);
re=re*16+c[i]+10-'A';
}
}
printf("\n%d\n",re);
return 0;
}