c语言中如何将10进制的浮点数转化为16进制数
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言中如何将10进制的浮点数转化为16进制数相关的知识,希望对你有一定的参考价值。
参考技术A 一、double的64位表达为:负号63,幂的负号62,2的幂61-52,精度表达51-0;double转为64位步骤:1、正为0,负为1,放在63位;
2、将数据表达成1.XXX*(2^I)形式,I为整数;
3、若I有负号,62位为1,否则为0;
4、I的绝对值有61-52位表达;
5、1.XXX去掉1成0.XXX;将Y=0.XXX表达为二进制;具体算法可以参考:for(int i=51;i>=0;i--)Y*=2;if(Y>=1)Y-=1;Result[i]=1;else Result[i]=0;Result[i]就是51-0位的数值;
6、将64位二进制表达成16进制;
C语言 如何将16进制形式的字符串,转化为相同的16进制的整型?
如何将16进制形式的字符串,转化为相同的16进制的整型。
例如:"0x123"的字符串转化为16进制也为0x123。
如果是要转换为在计算机内存储的变量的值,则是提问者对计算机的原理不理解。计算机中所有的数都是以二进制形式存储,才能直接进行计算的。如果是要把十六进制的字符串,转换为数值形式,实际上是转换为十进制值(计算机以二进制存储,十六进制形式是程序员为简便而产生的,它是二进制表示的另一种形式),可以以下面的代码实现:
int str2int(char s[])
int i,f;
for(i=f=0;s[i];i++)
if(s[i]>='0'&&s[i]<='9')f=f*16+s[i]-'0';
else if(s[i]>='a'&&s[i]<='f')f=f*16+s[i]-87;
else if(s[i]>='A'&&s[i]<='F')f=f*16+s[i]-55;
else return f;
追问
你这样只是把代码中字符串“0x123”变成了123 虽然这也是16进制 但是没有0x ,然后把你转化后的数给i,在代码中i=123,它会以十进制给i,虽然给i的只是一个数,存储来说都是二进制,但这里i的大小就是10,也就是0xa,这和所需求的0x123就不符了。 ***需求为:“0x123转换为在计算机内存储的变量的值,但是这里并不是要存”0x123“字符串的值,而是存0x123的值。
追答我的程序并不是把"0x123"变为123,而是变为0x123的等值十进制值291。因为它在计算机内存储的就是i=291的二进制值,只是在输出时,如果规定以printf("0x%x",i);就会得到输出0x123。
参考技术A 整形就是整数,不分几进制。几进制只是常量书写形式而已
以上是关于c语言中如何将10进制的浮点数转化为16进制数的主要内容,如果未能解决你的问题,请参考以下文章