习题7-8 字符串转换成十进制整数 【简单明了的解析】

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;
}

上一篇:Min_25筛目害学


下一篇:Python找出整数1、2、3、4能组成多少个各位互不相同且不重合的三位数,并输出这些三位数。