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