【发布时间】:2017-05-19 17:44:31
【问题描述】:
我有一个简单的程序,其中程序从文件接收输入并将十进制转换为二进制并计算二进制形式的个数? 现在对于小值没关系 对于像 15755645551 这样的巨大值,它显然不起作用 有人知道如何解决这个问题吗? 任何人都可以尝试使用我的代码? 谢谢!! 这是我的代码:
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
#define BUFFER 25
long number_read = 0;
long number_of_ones = 0;
long remainder_value = 0;
long binary = 0;
long base = 0;
long buff[BUFFER];
int main()
{
FILE *fp; //file pointer fp
fp = fopen("File.txt", "r+");
while (fgets(buff, sizeof(buff), fp) != NULL)
{
number_read = atoi(buff); //ASCII to integer
printf("\nnumber is=%d", number_read);
while (number_read > 0)
{
remainder_value = number_read % 2;
/* To count no.of 1s */
if (remainder_value == 1)
{
number_of_ones++;
}
binary = binary + remainder_value * base;
number_read = number_read / 2;
base = base * 10;
}
printf("\nNo.of 1's in It's binary representation is = %d\n", number_of_ones);
number_of_ones = 0;
}
fclose(fp);
return 0;
}
【问题讨论】:
-
你知道
15755645551可能不适合long吗? -
是的..其实我已经用long试过了,上面忘了说..需要试试long long
标签: c file binary file-handling decimalformat