描述
输入正整数a,b,c,输出a/b的小数形式,精确到小数点后c位(注意最后一位的四舍五入问题)。2 <= a,b,c <= 1000。(注意本题小数保留范围)。
输入
第1行是一个整数n,表示随后有n组数据。每组数据占一行,输入正整数a,b,c (2<=a,b,c<=1000),用空格隔开。
输出
对每组数据,计算并输出a/b的小数形式,保留小数点后c位,并换行,
#include <stdio.h>
#include <math.h>
#include <time.h>
int main()
{
int a, b, c;
int count = 0;
while ( scanf("%d %d %d", &a, &b, &c) == 3 && ( a != 0 || b!= 0 || c!=0) )
{
int front_point = a / b; //整数部分
int first_change = a % b; //第一次余数
int decimal[c+1];
decimal[0] = front_point;
int i = 1;
while ( i <= c )
{
first_change *= 10;
decimal[i++] = first_change / b;
first_change %= b;
}
//考虑进位
first_change *= 10;
if ( first_change / b >= 5) //第c+1位如果不小于5
{
decimal[c]++; //第c位进1
//考虑连续进位的可能性
for ( i = c; i >= 1; i--)
{
if (decimal[i] == 10)
{
decimal[i-1]++;
}
}
if (decimal[1] == 10) //如果第一位小数位为10
{
decimal[0]++;
}
//10变0
for (int k = 1; k <= c; k++)
{
if ( decimal[k] == 10)
{
decimal[k] = 0;
}
}
}
count++;
printf("Case %d: %d", count, front_point);
if ( c != 0)
{
printf(".");
for (int j = 1; j <= c; j++)
{
printf("%d", decimal[j]);
}
}
}
//printf("\nTime used = %.2f", (double)clock() / CLOCKS_PER_SEC);
return 0;
}