二进制 带小数 的字符串 转化为 float型
2011-08-11 16:08
225 查看
#include "iostream.h"
#include "stdio.h"
#include "string.h"
const int MAX=10;
float convert(const char* str)
{
float sum1 = 0.0;
float sum2 = 0.0;
int i = 0;
int idx = 0;
int len = strlen(str);
while(str[idx]!='.')
idx++;
printf("len is %d, index is %d\n", len, idx);
i = idx;
while(i--)
{
sum1 = (sum1*2) + (str[i]-'0'); //整数部分
}
i = len-1;
while(i>idx)
{
sum2 = (sum2 + (str[i]-'0'))*0.5; //重点所在啊,小数部分0.11 = (1/2) +(1/4)=0.75
i--;
}
printf("sum1 is %f, sum2 is %f\n", sum1, sum2);
return (sum1+sum2);
}
int main(int argc, char *argv[])
{
float ret = 0.0;
char str[MAX];
while(1)
{
printf("Please input the str:\n");
scanf("%s", str);
ret = convert(str);
printf("%f\n",ret);
}
// system("PAUSE");
return 0;
}
#include "stdio.h"
#include "string.h"
const int MAX=10;
float convert(const char* str)
{
float sum1 = 0.0;
float sum2 = 0.0;
int i = 0;
int idx = 0;
int len = strlen(str);
while(str[idx]!='.')
idx++;
printf("len is %d, index is %d\n", len, idx);
i = idx;
while(i--)
{
sum1 = (sum1*2) + (str[i]-'0'); //整数部分
}
i = len-1;
while(i>idx)
{
sum2 = (sum2 + (str[i]-'0'))*0.5; //重点所在啊,小数部分0.11 = (1/2) +(1/4)=0.75
i--;
}
printf("sum1 is %f, sum2 is %f\n", sum1, sum2);
return (sum1+sum2);
}
int main(int argc, char *argv[])
{
float ret = 0.0;
char str[MAX];
while(1)
{
printf("Please input the str:\n");
scanf("%s", str);
ret = convert(str);
printf("%f\n",ret);
}
// system("PAUSE");
return 0;
}
相关文章推荐
- 十进制小数转化为二进制小数
- 字符串与二进制互相转化(不包含汉字)
- C#double转化成字符串 保留小数位数, 不以科学计数法的形式出现
- Python---非负整数转化成二进制字符串
- Python 使用map()和reduce() 函数将带小数点的字符串数字转化成小数
- 将串口接收到的字符串转化为数值(包含小数)
- 小数转化为二进制
- C#double转化成字符串 保留小数位数, 不以科学计数法的形式出现。
- 字符串与二进制数组相互转化(数据加密原理)
- uva537字符串中小数转化为实际小数
- 十进制小数转化为二进制小数
- 十进制小数转化为二进制小数
- 转:十进制小数转化为二进制小数
- java实现将字符串转化为二进制输出
- 将16进制字符串转化成内存二进制数据
- C#double转化成字符串 保留小数位数, 不以科学计数法的形式出现。
- 二进制转化为16进制字符串
- 十进制小数转化为二进制小数
- 二进制转化字符串