字符串转换成十进制整数 (15 分)
输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。
输入格式:
输入在一行中给出一个以#结束的非空字符串。
输出格式:
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
输入样例:
±P-xf4±1!#
输出样例:
-3905
#include<stdio.h>
#include<string.h>
int main()
{
int i,j,k=0,n=0,flgh=1;
long s=0;
char a[100],b[100];
i=0;
while((a[i]=getchar())!='#') {
i++;
}
a[i]='\0';
for(j=0; a[j]!='\0'; j++) {
if(a[j]>='0'&&a[j]<='9'||a[j]>='A'&&
a[j]<='F'||a[j]>='a'&&a[j]<='f') {
b[k]=a[j];
k++;
}
}
b[k]='\0';
for(j=0;a[j]!='\0';j++){
if(a[j]=='-') n++;
if(a[j]>='0'&&a[j]<='9'||a[j]>='A'&&
a[j]<='F'||a[j]>='a'&&a[j]<='f') break;
}
if(n>=1) flgh=-1;
for(i=0; b[i]!='\0'; i++) {
if(b[i]>='0'&&b[i]<='9') s=s*16+(b[i]-'0');
else if(b[i]>='A'&&b[i]<='F') s=s*16+(b[i]
-'A')+10;
else if(b[i]>='a'&&b[i]<='f') s=s*16+(b[i]
-'a')+10;
}
printf("%ld",s*flgh);
return 0;
}