十进制转化为十六进制代码:
#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
参考资料:
百度百科-进制转换
C语言十进制转十六进制数的源代码如下:
#include<bits/stdc++.h>
using namespace std
void IntZh0x(int n)
{int s=n%16
if(n/16!=0) IntZh0x(n/16)
if(s>9)
{
if(s==15) cout<<"F"
else if(s==14) cout<<"E"
else if(s==13) cout<<"D"
else if(s==12) cout<<"C"
else if(s==11) cout<<"B"
else if(s==10) cout<<"A"
}
else cout<<s
}
int main(){
int n
cin>>n
IntZh0x(n)
return 0
}
扩展资料
1、十六进制数转换成十进制数解,其值为各个位码乘以位权然后完全相加。
2、十六进制就是把 4 个二进制位组合为一位来表示,每一位有0b0000 ~ 0b1111 共 16 个值,用 0 ~ 9 再加上 A ~ F(或 a ~ f)表示,那么它自然就是逢十六进位,它本质上同二进制是一样的,是二进制的一种缩写形式。