在KEIL软件上建立工程项目,编辑C语言,编译调试无错后,点击project下的options for target,在output标签下勾选输出HEX,确定后就在编译一下会自动生成HEX文件在相同目录里。
十进制转化为十六进制代码:
#include "stdio.h" int main()
{
int num=0
int a[100]
int i=0
int m=0
int yushu
char hex[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}
printf("请输入一个十进制数:")
scanf("%d",&num) while(num>0) { yushu=num%16
a[i++]=yushu
num=num/16
} printf("转化为十六进制的数为:0x") for(i=i-1i>=0i--)//倒序输出 {m=a[i]
printf("%c",hex[m]) } printf("\n")
}
程序运行结果:
扩展资料:
进制转换由一组数码符号和两个基本因素“基数”与“位权”构成。基数是指,进位计数制中所采用的数码(数制中用来表示“量”的符号)的个数。位权是指,进位制中每一固定位置对应的单位值。
举例:二进制数转换为十进制数
二进制数第0位的权值是2的0次方,第1位的权值是2的1次方……
所以,设有一个二进制数:0110 0100,转换为10进制为:
下面是竖式:
0110 0100 换算成十进制
第0位 0 * 20 = 0
第1位 0 * 21 = 0
第2位 1 * 22 = 4
第3位 0 * 23 = 0
第4位 0 * 24 = 0
第5位 1 * 25 = 32
第6位 1 * 26 = 64
第7位 0 * 27 = 0
公式:第N位2(N)
---------------------------
100
用横式计算为:
0 * 20 + 0 * 21 + 1 * 22 + 0 * 23 + 0 * 24 + 1 * 25 + 1* 26 + 0 * 27 = 100
0乘以多少都是0,所以我们也可以直接跳过值为0的位:
1 * 22 + 1 * 25 +1*26 = 100
参考资料:
百度百科-进制转换