1. c语言十进制转化为十六进制
十进制转化为十六进制代码:
#include"stdio.h"intmain()
{
intnum=0;
inta[100];
inti=0;
intm=0;
intyushu;
charhex[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-1;i>=0;i--)//倒序输出{m=a[i];
printf("%c",hex[m]);}printf(" ");
}
程序运行结果:
(1)c语言十进制的状态转换图扩展阅读:
进制转换由一组数码符号和两个基本因素“基数”与“位权”构成。基数是指,进位计数制中所采用的数码(数制中用来表示“量”的符号)的个数。位权是指,进位制中每一固定位置对应的单位值。
举例:二进制数转换为十进制数
二进制数第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
2. C语言如何实现十六进制转换成十进制
C语言实现十六进制转换成十进制如下:
例如将十六进制数字 9FA8C 转换成十进制:
9FA8C = 9×164 + 15×163 + 10×162 + 8×161 + 12×160 = 653964(十进制)。
从右往左看,第1位的位权为 160=1,第2位的位权为 161=16,第3位的位权为 162=256,第4位的位权为 163=4096,第5位的位权为 164=65536 …… 第n位的位权就为 16n-1。
将各个位的数字乘以位权,然后再相加,就得到了十进制形式。
十六进制数的第0位的权值为16的0次方,第1位的权值为16的1次方,第2位的权值为16的2次方。
所以,在第N(N从0开始)位上,如果是是数 X (X 大于等于0,并且X小于等于 15,即:F)表示的大小为 X * 16的N次方。
再例如:十六进制:EA7 = 14×162 + 10×161 + 7×160 = 3751(十进制)。
(2)c语言十进制的状态转换图扩展阅读:
C语言10进制转16进制
把十进制的数不停除以16的余数按从右到左的顺序排起来就是16进制,例如:55/16=0余5例如100 100/16=6余4 6/16余6,所以就是64,再例如1000 1000/16=62余8 62/16=3余12 3/16余3所以结果是3C8 //。
对于整数部分,用被除数反复除以2,除第一次外,每次除以2均取前一次商的整数部分作被除数并依次记下每次的余数。另外,所得到的商的最后一位余数是所求二进制数的最高位。
对于小数部分,采用连续乘以基数2,并依次取出的整数部分,直至结果的小数部分为0为止。
3. C语言中怎样调用函数将十进制转换成二进制
1、打开visualC++6.0-文件-新建-文件-C++SourceFile。
4. 用C语言进行十进制和八进制的转换怎么做
如果输入是十进制字符串,输出是八进制字符串,则用如下dec2oct函数可实现转换
#include<stdio.h>
intdec2oct(char*dec,char*oct){
intnum=0,i=0,t;
charc;
do{
c=*dec;
if(!c)return0;//出错了,没找到10进制数
if(c>='0'&&c<='9')break;//找到十进制数了
elsedec++;
}while(1);
do{
num=num*10+(c-'0');
c=*++dec;
if(!c)break;//没有其他字符了
if(c>='0'&&c<='9')continue;//还有十进制字符,继续
elsebreak;//没有其他十进制字符了,退出
}while(1);
do{
t=num%8;
oct[i]=t+'0';
num=num/8;
if(num==0)break;
i++;
}while(1);
for(t=(i+1)/2;t<=i;t++){
num=oct[t];
oct[t]=oct[i-t];
oct[i-t]=num;
}
oct[i+1]='