#include "stdio.h" #include "stdlib.h" #include "string.h" #define datatype int #define MAX_SIZE 50 #define OK 1 #define Err 0 /** * Code : By YangLong 2014年9月21日, * * 0x00: 函数说明 * XD2B 将任意一个 浮点数 转换为 2 进制 * XD2B(double f,char* s, bool z) * 参数一: 需要转换的浮点数 * 参数二: 存放结果的字符数组 * 参数三: z = true 时 代表 整数转换 * z = false 时 表示浮点数 转换 * * 0x01 IEEE754(char* s) * 参数一: 将 XD2B中的字符数组 转换为 IEEE754格式 * 0x02 不足: * 结果显示为 拆分项 * 要链接起来 用 字符串 拼接 就行 * * 0x03 待优化: * 结果显示为 16进制 * 将IEEE754转换为真值 * * 不是程序复杂,而是编写的有点乱。 */ typedef struct Stack { datatype data[MAX_SIZE]; int top; }stk; void Init(stk* s) { s->top = -1; } bool push(stk *s,datatype d) { if(s->top+1>MAX_SIZE-1) { printf(" ‘push‘ Error: Overflow!\n"); exit(0); } s->data[++s->top] = d; return OK; } datatype pop(stk* s) { if(s->top<0) { printf(" ‘pop‘ Error: Overflow!"); exit(0); } datatype data = s->data[s->top--]; return data; } bool IsEmpty(stk* s) { return s->top == -1 ? OK : Err; } void XD2B(double f,char* s, bool z) { int i=0,j=0; stk ss; Init(&ss); if(f<0) { s[0] = ‘1‘; j = 1; f = f*(-1.0); } else { s[0] = ‘0‘; j = 1; } int q = (int)f; while(q) { push(&ss,q%2); q = q/2; } while(!IsEmpty(&ss)) { s[j++] = pop(&ss) + ‘0‘; } if(z) // z整形运算 return; s[j++] = ‘.‘; f = f - (int)f; while(i<23) { f = f*2; s[j+i] = (int)f + ‘0‘; f = f - (int)f; i++; } } void IEEE754(char* s) { int j=1,i = 0,q,e,jm=0; while(s[++i]!=‘.‘); int m=1; if(i>1) { while(s[m]!=‘1‘ && m<strlen(s)) m++; //printf("\n i = %d m= %d i - m = %d ",i,m,i - m-1); //去掉符号位 jm = i-m-1; } else { while(s[m]!=‘1‘ && m<strlen(s)) m++; //printf("\n i = %d m= %d i - m = %d ",i,m,i - m); //去掉符号位 jm = i-m; } int js = jm; jm = jm + 127; char cjm[16] = {0}; char ws[65]={0}; XD2B(jm,cjm,true); //整形 转换 printf("\n符号位: %c",s[0]); printf("\n阶码: %s\n",&cjm[1]); for(q= i -js,e=0; q<strlen(s);q++) { if(s[q] != ‘.‘) ws[e++] = s[q]; } printf("尾数: %s",ws); } void main() { printf("Code By YangLong 0.o\n "); printf("IEEE754 ->:"); char s[80]={0}; double df=0.0; scanf("%lf",&df); XD2B(df,s,false); printf("%.16lf 二进制小数: ",df); bool flag =true; int j = 0; for(int i=0;i<strlen(s);i++) { putchar(s[i]); if(i == 0) { putchar(‘ ‘); //符号位 } else if(i%4 ==0 ) //控制 putchar(‘ ‘); } IEEE754(s); printf("\n"); getchar(); getchar(); }
原文:http://black4yl.blog.51cto.com/4222963/1589779