1、题目
输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。
输入格式:
输入在一行中给出一个以#结束的非空字符串。
输出格式:
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
2、解析
(1)掌握十六进制字符转化为十进制的方法
①sum=sum*16+ch-'0' (ch是0~9的十六进制字符时)
②sum=sum*16+ch-'A' (ch是A~F的十六进制字符时)
③sum=sum*16+ch-'a' (ch是a~f的十六进制字符时)
(2)注意:如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。所以设置变量count,如果已经读入十六进制字符,就改变其值,以此判断符号是不是在此之前出现的。
#include<stdio.h>
int main()
{
char ch;
int flag=1,sum=0,count=0; //flag用来判断正负,count用来判断负号是在十六进制数之前还是之后出现
while((ch=getchar())!='#')
{
if (ch=='-'&&count==0)
{
flag=-1;
}
if(ch>='0'&&ch<='9')
{
sum=sum*16+ch-'0';
count++;
}
if(ch>='a'&&ch<='f')
{
sum=sum*16+ch-'a'+10;
count++;
}
if(ch>='A'&&ch<='F')
{
sum=sum*16+ch-'A'+10;
count++;
}
}
sum*=flag;
printf("%d",sum);
return 0;
}