1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > c语言(编程题:十六进制数转换为十进制)

c语言(编程题:十六进制数转换为十进制)

时间:2021-10-21 04:16:09

相关推荐

c语言(编程题:十六进制数转换为十进制)

C语言

题目

写一个函数,输入一个十六进制数,输出相应的十进制数。

基础知识

1. 十六进制定义

-------16进制即逢16进1,每一位上可以是从小到大为0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F共16个大小不同的数。16进制转换即16进制与其他不同进制之间的换算转换,常见如2进制、8进制、10进制等进制。

且16进制的标准表示一般为0x后跟数字

2.十六进制转换

-------十六进制转换有16进制每一位上可以是从小到大为0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F16个大小不同的数,即逢16进1,其中用A,B,C,D,E,F(字母不区分大小写)这六个字母来分别表示10,11,12,13,14,15。

3. 各种进制对照表:

分析题目

首先明白16进制如何通过计算转换为10进制。

--------16进制数的第0位的权值为16的0次方,第1位的权值为16的1次方,第2位的权值为16的2次方……所以,在第N(N从0开始)位上,如果是是数 X (X 大于等于0,并且X小于等于 15,即:F)表示的大小为 X * 16的N次方。

举例: 将0x2AF5换算成10进制

5 * 16^0 + F * 16^1 + A * 16^2 + 2 * 16^3 = 10997

编程解决

将问题分析过后我们知道了两种进制转换的原理,也会进行进制转换的计算,现在我们需要把这些数学思想转换为编程语言。

并且在进制转换的编程中有许多小问题一下将会做出详解。

1.先定义编写函数的名称:

int Get_0x(const char* str)//将函数命名为Get_0x 并且形参为不可修改的字符串

2.进制转换函数用到的头文件:

#include <stdio.h>//标准库函数#include <ctype.h>//特殊字符判断的头文件#include <string.h>//字符串操作用到的头文件#include <limits.h>//检测整型数据类型的表达式范围

3.如果遇到空格的处理:

while (isspace(*str)){str++;//因为空格在转换过程中对数值没有影响,直接++后移进行后续操作}

4.正负号的判断及解决方法:

int index = 1;if (*str == '-' || *str == '+'){if (*str == '-'){index *= -1;}else{index = 1;}str++;}

5.判断前两位是否是0X 16进制的表达形式:

if ((*str == '0') && (*(str + 1) == 'x' || *(str + 1) == 'X'))//判断前两位是否是0X 16进制的表达形式{str += 2;//如果是从第三位开始换算计算}else{return INT_MAX;}

6.判断是否是字符:

while (isxdigit(*str)) //判断是否是字符{if (isdigit(*str)) //如果是字符按位进行操作 这部分就是将数学思想转变为编程语言{sum = sum * 16 + (*str - '0');}else if (islower(*str)){sum = sum * 16 + (*str - 'a' + 10);}else{sum = sum * 16 + (*str - 'A' + 10);}str++;}

7.结束标志:

if (*str == '\0')return sum * index;return INT_MAX;

上述就是进制转换各部分的代码及其实现的功能。

全部代码

#include <stdio.h>#include <ctype.h>#include <string.h>#include <limits.h>int Get_0x(const char* str){int sum = 0;while (isspace(*str)){str++;}//此时 空格处理结束int index = 1;if (*str == '-' || *str == '+'){if (*str == '-'){index *= -1;}else{index = 1;}str++;}if ((*str == '0') && (*(str + 1) == 'x' || *(str + 1) == 'X'))//判断前两位是否是0X 16进制的表达形式{str += 2;//如果是从第三位开始换算计算}else{return INT_MAX;}while (isxdigit(*str)) //判断是否是字符{if (isdigit(*str)){sum = sum * 16 + (*str - '0');}else if (islower(*str)){sum = sum * 16 + (*str - 'a' + 10);}else{sum = sum * 16 + (*str - 'A' + 10);}str++;}if (*str == '\0')return sum * index;return INT_MAX;}int main(){printf("%d\n", Get_0x("0x123ABcW"));printf("%d\n", Get_0x("0X123ABc"));printf("%d\n", Get_0x("0x123ABc"));//对空格判断printf("%d\n", Get_0x("+0x123ABc"));//+判断printf("%d\n", Get_0x("-0x123ABc"));//-判断printf("%d\n", Get_0x(" +0x123ABc"));//+和空格判断printf("%d\n", Get_0x(" -0x123ABc"));//-和空格判断printf("%d\n", Get_0x("0x2AF5"));//对上述举例进行验证}

验证结果

(小白一位,如有问题,欢迎各位大佬指正)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。