十六进制转十进制————蓝桥杯、常见题型(详细分析,C语言)

一、问题描述

  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。

样例输入

FFFF

样例输出

65535

 二、解题思路分析:

首先我们要学会十六进制转十进制的数学方法:

1、首先明白16进制数(从右到左数是第0位,第1位,第2位……)的第0位的权值为16的0次方,第1位的权值为16的1次方,第2位的权值为16的2次方,依次这样排列下去。

2、明白ABCDEF表示的二进制数字分别是10,11,12,13,14,15。

3、十六进制转换成十进制的公式是:要从右到左用二进制的每个数去乘以16的相应次方,然后这些数字相加就是了。

其次我们需要了解在C语言中,字符与整型常量相减,其结果就相当与字符对应的ascll码表值减去整型变量的值.

三、代码展示:

#include <stdio.h>
#include <stdlib.h>
#include<math.h>
#include<string.h>
int main(int argc, char *argv[]) {
	int i,b=0;
long long int q[1000]={0};
long long int sum=0;
int m=0;
char a[10000];
char h[10000];
int s[10000];
char n=1;
for(i=0;i<n;i++)
	{
		scanf("%s",a);
	b=strlen(a);
	for(i=0;i<b;i++)//这个for循环是为了将输入的信息进行处理然后用于十进制的计算 
	   {
	   //因为十六进制中包含数字和字母,因此需要进行分类处理 
	   
	      if(a[i]>='0'&&a[i]<='9')  //第一种情况当输入的信息为数字时,如果在零到九之间那么就直接将字符转化为数字即可 
	    {
		   h[i]=a[i]-'0';//这一步骤就是将字符转化为数字 
     	}
		   
           else if(a[i]>='A'&&a[i]<='F') //第二种情况就是当输入的信息为字母时需要将字母变换为对应的数字(如:A表示10;B表示11) 
           {
           	h[i]=a[i]-55; //根据ascll 码表可以得出,A对应的ascll码表值为65,因此只需要减去55,那么此时就可以实现字母与数字进行对应转换 
           }
	  }
   for(i=0;i<b;i++)//将输入信息进行分析之后,进入十六进制转十进制的计算 
   {
     q[i]=h[i]*pow(16.0,b-i-1);  //十六进制转十进制的公式 
     sum=sum+q[i];
   }
   }
printf("%I64d\n",sum);
	return 0;
}

 五、运行结果展示:

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值