我们经常碰到16进制数转10进制的情况,使用下面的C程序即可完成上述工作。

那么他是怎样的工作原理呢?

6.2.5 十六进制数转换成十进制数
 
16进制就是逢16进1,但我们只有0~9这十个数字,所以我们用A,B,C,D,E,F这五个字母来分别表示 10,11,12,13,14,15。字母不区分大小写。
十六进制数的第0位的权值为16的0次方,第1位的权值为16的1次方,第2位的权值为16的2次方……
所以,在第N(N从0开始)位上,如果是是数 X (X 大于等于0,并且X小于等于 15,即:F)表示的大小为 X * 16的N次方。
假设有一个十六进数 2AF5, 那么如何换算成10进制呢?
 
用竖式计算:
 
2AF5换算成10进制:
 
第0位: 5 * 16

0

= 5
第1位: F * 16

1

 = 240
第2位: A * 16

2

= 2560
第3位: 2 * 16

3

 = 8192  +
-------------------------------------
10997
直接计算就是:
(5 * 16

0

 ) + (F * 16

1

 ) + (A * 16

2

 ) + (2 * 16

3

)= 10997
(别忘了,在上面的计算中,A表示10,而F表示15)
 

注*

以此,程序的需要两部分组成:

1. 权值计算

16的几次方,power(16, x)

unsigned long power(int a, int b)
{
int i;
unsigned long result = 1;
for(i = 0; i < b; i++)
{
result *= a;
} return result;
};

2. 单16进制值转10进制值

例如:如果是F,则表示15

   switch (ch)
{
case '0':
iCh = 0;
break;
case '1':
iCh = 1;
break;
case '2':
iCh = 2;
break;
case '3':
iCh = 3;
break;
case '4':
iCh = 4;
break;
case '5':
iCh = 5;
break;
case '6':
iCh = 6;
break;
case '7':
iCh = 7;
break;
case '8':
iCh = 8;
break;
case '9':
iCh = 9;
break;
case 'a':
iCh = 10;
break;
case 'b':
iCh = 11;
break;
case 'c':
iCh = 12;
break;
case 'd':
iCh = 13;
break;
case 'e':
iCh = 14;
break;
case 'f':
iCh = 15;
break; default:
iCh = -1;
break;
}

为了满足,把所有输入转换为小写字母,可以使用系统函数tolower()或者我们自己写的函数toLower()

int toLower(int c)
{
if(c >= 'A' && c <= 'Z')
{
return c + 'a' - 'A';
} else {
return c;
}
};

完整程序如下:

/*
* hex2int.c
*
* Created on: 2010-07-20
* Author: xiaobin
*
*/ #include <stdio.h>
/* #include <math.h> */
#include <string.h>
//#include <ctype.h> /* int max is 32767 */
/* "%d" only print int */
/* long max is 2147483647 */
/* "%ld" can print long type */
/* unsigned long max is 4294967295 */
/* "%lu" can print unsigned long type */ #define MB 0x0100000UL unsigned long power(int a, int b);
int toLower(int c);
unsigned long htoi(char s[]); int main(int argc, char* argv[])
{
if(argc > 1)
printf("long integer: %lu\n", htoi(argv[1]));
printf("M/Byte: %ld\n", MB);
return 0;
} unsigned long htoi(char *s)
{
int i, len;
unsigned long value, result;
int iCh;
unsigned long iPow;
int pos;
char ch; result = 0;
len = 0;
value = 0;
iCh = -1; len = strlen(s);
pos = 0; len -= 1; for(i = len; (s[i] >= '0' && s[i] <= '9')
|| (s[i] >= 'a' && s[i] <= 'f')
|| (s[i] >= 'A' && s[i] <= 'F'); i--) { ch = toLower(s[i]); /* tolower() defined in ctype.h */ switch (ch) {
case '0':
iCh = 0;
break;
case '1':
iCh = 1;
break;
case '2':
iCh = 2;
break;
case '3':
iCh = 3;
break;
case '4':
iCh = 4;
break;
case '5':
iCh = 5;
break;
case '6':
iCh = 6;
break;
case '7':
iCh = 7;
break;
case '8':
iCh = 8;
break;
case '9':
iCh = 9;
break;
case 'a':
iCh = 10;
break;
case 'b':
iCh = 11;
break;
case 'c':
iCh = 12;
break;
case 'd':
iCh = 13;
break;
case 'e':
iCh = 14;
break;
case 'f':
iCh = 15;
break; default:
iCh = -1;
break;
} iPow = power(16, pos);
pos++; value = iPow * iCh; result += value;
} return result;
}; unsigned long power(int a, int b)
{
int i;
unsigned long result = 1;
for(i = 0; i < b; i++)
result *= a; return result;
}; int toLower(int c)
{
if(c >= 'A' && c <= 'Z')
return c + 'a' - 'A';
else
return c;
};

在CDT编译通过。

如有疑问请参考:《使用CDT+cygwin编写C/C++

注*: 参考文章《第六章 二进制、八进制、十六进制》 - 第2学堂南郁

十六进制转十进制 - C的更多相关文章

  1. [No000071]C# 进制转换(二进制、十六进制、十进制互转)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  2. 十六进制转十进制函数_C编程

    /**************************十六进制转十进制函数**************************//*函数原型:uint htd(uint a)/*函数功能:十六进制转十 ...

  3. UTC格式转换 & 十六进制换算为十进制

    UTC格式转换成北京时间格式: /// <summary> /// UTC格式与datatime的转换 /// </summary> /// <param name=&q ...

  4. BCD码、十六进制与十进制互转

    在做嵌入式软件的设计中,常常会遇到十六进制.BCD码与十进制之间的转换,近期做M1卡的应用中,涉及了大量的十六进制.BCD码与十进制之间的转换.通过对BCD码.十六进制 权的理解,轻松的实现了他们之间 ...

  5. C语言的本质(2)——二进制、八进制、十六进制与十进制

    二进制是计算技术中广泛采用的一种数制.二进制数据是用0和1两个数码来表示的数.它的基数为2,进位规则是"逢二进一",借位规则是"借一当二",由18世纪德国数理哲 ...

  6. C# 进制转换(二进制、十六进制、十进制互转)

    原文地址:https://www.cnblogs.com/icebutterfly/p/8884023.html C# 进制转换(二进制.十六进制.十进制互转)由于二进制数在C#中无法直接表示,所以所 ...

  7. 八进制、十六进制与十进制的转换,bytes的十六进制

    二进制.八进制.十六进制与十进制的不同顾名思义在于进位不同: 十进制遇十进一,9+1=10,19+1=20,199+1=200.相同数字前一位是后一位的十倍,例如11,前一个代表10,后一个是1. 一 ...

  8. lqb 基础练习 十六进制转十进制

    基础练习 十六进制转十进制 时间限制:1.0s   内存限制:512.0MB     问题描述 从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出. 注:十六进制数中的10~ ...

  9. JAVA 十六进制和十进制、二进制转换

    java十六进制和十进制.二进制转换 十进制转化成十六进制 Integer x = 100; hex = x.toHexString(x); 十六进制转化成十进制 Integer.parseInt(h ...

  10. python实现进制转换(二、八、十六进制;十进制)

    python实现进制转换(二.八.十六进制:十进制) (一)十进制整数转为二.八.十六进制 1.format实现转换>>> format(2,"b") # (10 ...

随机推荐

  1. UVa 12034 (递推) Race

    题意: 有n个人赛马,名次可能并列,求一共有多少种可能. 分析: 设所求为f(n),假设并列第一名有i个人,则共有C(n, i)种可能,接下来确定后面的名次,共有f(n-1)种可能 所以递推关系为: ...

  2. LA 3890 (半平面交) Most Distant Point from the Sea

    题意: 给出一个凸n边形,求多边形内部一点使得该点到边的最小距离最大. 分析: 最小值最大可以用二分. 多边形每条边的左边是一个半平面,将这n个半平面向左移动距离x,则将这个凸多边形缩小了.如果这n个 ...

  3. datatables 参数详解(转)

    //@translator codepiano //@blog codepiano //@email codepiano.li@gmail.com //尝试着翻译了一下,难免有错误的地方,欢迎发邮件告 ...

  4. linux - 开机启动thunderbird、chromium

    cd ~/.config/autostart/(没有autostart,自己 mkdir autostart) vim thunderbird.desktop,输入以下: [Desktop Entry ...

  5. DirectX截图黑屏的解决办法

    好久没有更新博客了,今天开始继续耕耘. 生活要继续 工作要继续 梦想也一定要继续! 之前写过一篇关于DirectX截屏的文章,其中有网友留言提到了截图黑屏的问题,于是这些日子研究了一下,与大家一同分享 ...

  6. POJ 1423 Big Number

    题意:求n阶乘的位数. 解法:斯特林公式,,然后取log10就是位数了,因为精度问题需要化简这个式子,特判1. 代码: #include<stdio.h> #include<iost ...

  7. Google服务背后的天文数字

    每天当我们在互联网上驰骋的时候,在背后支撑网页.应用.服务运转的就是各种编程语言和代码.无论是Gmail确认收件箱还是执行关键词搜索都需要大量的代码,但是你知道Google的各项互联网服务合起来需要多 ...

  8. AppServ的安装与配置

    AppServ是一个软件集合,包括Apache(HTTP服务器软件).PHP(网页程序设计语言).MySQL(数据库管理系统软件).phpMyAdmin(图形界面的数据库管理软件)四个组成部分.App ...

  9. 建立简单的VLAN通信

    http://minitoo.blog.51cto.com/4201040/786011(转载) 在路由器上做单臂路由实现VLAN间路由,也就是设置子接口和封装协议. 实现环境如下图: 在交换机上建立 ...

  10. oracle修改密码及账户锁定

    在oracle修改密码的时候,一种是用dba账户来修改用户的密码,一种是用户自己修改自己的密码: SQL> alter user kel identified by kel; 解锁命令: SQL ...