PTA第五次实验 7-9 字符串转换成十进制整数

题目描述:

输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。

输入格式:

输入在一行中给出一个以#结束的非空字符串。

输出格式:

在一行中输出转换后的十进制数。题目保证输出在长整型范围内。

输入样例:

±P-xf4±1!#

输出样例:

-3905

题目解析

这道题感觉是这个实验最难的一道题,总之就是麻烦,其中主要是几个问题:1.不区分大小写,就需要我们把大小写统一。2.我们需要把多余的不是16进制的字符去掉,同时我们需要判断一下只有‘-’以及十六进制符号时,第一个字符是不是‘-’,因此我们必须先保留‘-’,再去掉‘-’。3.把十进制的数转化为十六进制
同时要注意的是 字符在运算时,并不是根据它表示的数,而是它的ascll码值,因此我们需要根据ascll码值再进行运算,具体的做法在下面的代码中有备注。

#include<stdio.h>
#include<string.h>
#include<math.h>
int main()
{
	char s[1000];
	int i;
    scanf("%s",s);
    i=strlen(s);       /*这是用来求字符串长度的函数*/
	int z=0,k=0;
	while(k<i)
	{
		if(s[k]>='A' && s[k]<='Z') s[k]+=32;        /*将大写字母都转化为小写字母*/
		k++;
	}
	k=0;
	while(k<i)
	{
		if((s[k]>='0' && s[k]<='9') || (s[k]>='a' && s[k]<='f') || s[k]=='-')    
		{
			if(s[k]=='-') z=1;    /*判断只有‘-’以及十六进制符号时,第一个字符是不是‘-’,并进行记录*/
			break;
		}
		k++;
	}
	k=0;
	int j=0;
	while(k<i)
	{
		if((s[k]>='0' && s[k]<='9') || (s[k]>='a' && s[k]<='f'))
		{
			s[j]=s[k];             /*去掉不是十六进制的字符*/
			j++;
		}
		k++;
	}
	k=0;
	int sum=0;
	for(k=0;k<j;k++)
	{
		if(s[k]>='0' && s[k]<='9')
		sum+=(s[k]-48)*pow(16,(j-k-1));          /*将字符串转化为16进制的整数*/
		if(s[k]>='a' && s[k]<='f')
		sum+=(s[k]-87)*pow(16,(j-k-1));
	}
	if(z==1) sum=-sum;      /*根据上面的记录,判断是不是负数*/
	 printf("%d",sum);   
	return 0;
	
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值