C语言十进制转换成二进制(可转换小数)哪里出错了?

//
#include
#include
#define decimalnum 8//小数二进制位数
void main()
{
char Integerbuffer[100];//整数
char decimalbuffer[20];//小数
float number;
double decimalnumber,a;
long value;
int i;
printf("请输入需要转换成二进制的十进制数:");
scanf("%f",&number);
//printf("\n%f\n",number);
value=(long)number;
a=decimalnumber=number-value;
//printf("%f\n",decimalnumber);
itoa(value, Integerbuffer, 2); // 将value 转为存成2进制之字串
printf("整数的二进制为%s\n",Integerbuffer);
//printf("%s",itoa(value, Integerbuffer, 2));
while(a>0.0)
{
decimalbuffer[i]='0'+(int)(a*2);
//printf("%d",(int)(a*2));
a=a*2-(int)(a*2);
if (i++==decimalnum) break;
}
decimalbuffer[i]='\0';
printf("小数的二进制形式为.%s\t\n",decimalbuffer);
printf("%f的二进制为%s.%s\n",number,Integerbuffer, decimalbuffer);
system("pause");
}

没有初始化i?初始化后再看看还有啥错误不

图片说明

 // app1.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

#include <stdio.h>
#include<stdlib.h>
#define decimalnum 8//小数二进制位数 
void main()
{
char Integerbuffer[100];//整数
char decimalbuffer[20];//小数
float number;
double decimalnumber,a;
long value;
int i=0;
printf("请输入需要转换成二进制的十进制数:");
scanf("%f",&number);
//printf("\n%f\n",number);
value=(long)number;
a=decimalnumber=number-value;
//printf("%f\n",decimalnumber);
itoa(value, Integerbuffer, 2); // 将value 转为存成2进制之字串
printf("整数的二进制为%s\n",Integerbuffer);
//printf("%s",itoa(value, Integerbuffer, 2));
    while(a>0.0)
    {
        decimalbuffer[i]='0'+(int)(a*2);
        //printf("%d",(int)(a*2));
        a=a*2-(int)(a*2);
        if (i++==decimalnum) break;
    }
    decimalbuffer[i]='\0';
    printf("小数的二进制形式为.%s\t\n",decimalbuffer);
    printf("%f的二进制为%s\.%s\n",number,Integerbuffer, decimalbuffer);
    system("pause");
}

int i=0;
这样就可以了。

请输入需要转换成二进制的十进制数:123.125
整数的二进制为1111011
小数的二进制形式为.001
123.125000的二进制为1111011.001
请按任意键继续. . .

public class getMaxMin {
    /**
     * 分治思想:先分别求出前半部分和后半部分数组的最大值和最小值,
     * 两部分中的最大值和最小值分别比较求出整个数组的最大值和最小值  
     * 比较次数为3*N/2-2次
     * @param arr
     * @param start
     * @param end
     * @param Max
     * @param Min
     */
    public static void findMaxMin(int[] arr,int start,int end,int Max,int Min){
        if(end - start <= 1){
            if(arr[start] > arr[end]){
                Max = arr[start];
                Min = arr[end];
            } else{
                Max = arr[end];
                Min = arr[start];
            }
            return;
        }
        int leftMax = 0;
        int leftMin = 0;
        int rightMax = 0;
        int rightMin = 0;
        findMaxMin(arr,start,(start + end) / 2,leftMax,leftMin);
        findMaxMin(arr,(start + end) / 2 + 1,end,rightMax,rightMin);

        Max = leftMax > rightMax ? leftMax : rightMax;
        Min = leftMin < rightMin ? leftMin : rightMin;
    }
    public static void main(String[] args) {
        int max = 0;
        int min = 0;
        int arr[] = {7,3,19,48,4,17,-12,10};
        findMaxMin(arr,0,arr.length - 1,max,min);
        System.out.println("max = " + max);
        System.out.println("min = " + min);
    }
}