二进制 带小数 的字符串 转化为 float型

本文详细介绍了如何使用C语言实现浮点数到字符串和字符串到浮点数的转换过程,包括解析整数部分和小数部分,并通过实例演示了转换的具体步骤。
 

#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;
}

小数二进制换为八进制数,可以按照以下步骤进行: 1. 将二进制数按照小数点位置分成整数部分和小数部分。 2. 将整数部分从右往左每三位一组,换为对应的八进制数。 3. 将小数部分从左往右每三位一组,换为对应的八进制数。 4. 将整数部分和小数部分的八进制数相加,得到最终的八进制数。 举个例子,假设要将二进制数1011.01101换为八进制数: 整数部分为1011,小数部分为0.01101。 整数部分按照每三位一组分为1和011,对应的八进制数为1和3。 小数部分按照每三位一组分为011和010,对应的八进制数为3和2。 将1+3和0.3相加,得到最终的八进制数13.3。 下面是一个使用C语言实现该换过程的代码示例: ```c #include <stdio.h> #include <math.h> #include <string.h> int main() { char binary[32]; // 存储二进制数的字符串 int int_part = 0; // 存储整数部分的八进制数 float float_part = 0.0; // 存储小数部分的八进制数 printf("请输入一个二进制数(小数部分用 . 分隔):"); scanf("%s", binary); // 按小数点位置分离整数部分和小数部分 char* dot = strchr(binary, '.'); if (dot != NULL) { *dot = '\0'; float_part = strtof(dot + 1, NULL); } // 将整数部分每三位一组换为八进制数并相加 int len = strlen(binary); for (int i = 0; i < len; i += 3) { int bits[3] = {0, 0, 0}; for (int j = 0; j < 3 && i + j < len; j++) { bits[j] = binary[len - i - j - 1] - '0'; } int octal = bits[0] + bits[1] * 2 + bits[2] * 4; int_part += octal * pow(10, i / 3); } // 将小数部分每三位一组换为八进制数并相加 for (int i = 0; i < 9; i += 3) { int bits[3] = {0, 0, 0}; for (int j = 0; j < 3 && i + j < 9; j++) { bits[j] = (int)(float_part * pow(2, i + j)) % 2; } int octal = bits[0] + bits[1] * 2 + bits[2] * 4; float_part += octal * pow(10, -i / 3 - 1); } // 输出最终的八进制数 printf("换为八进制数为:%o.%o\n", int_part, (int)(float_part * 1000)); return 0; } ``` 在代码中,使用了 `strchr` 函数在字符串中查找小数点的位置,并使用了 `strtof` 函数将小数部分换为浮点数。在将整数部分和小数部分换为八进制数时,使用了 `pow` 函数计算幂次,以实现每三位一组换的功能。最后使用 `%o` 格式输出八进制数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值