《算法竞赛入门经典》——习题2-5 分数化小数(decimal)

这篇博客探讨了如何将分数a/b转换为精确到小数点后c位的十进制形式,涉及ACM算法竞赛中的习题。通过分析两种方法,包括使用%.*lf的不足和手动逐位计算的正确方法,为读者提供了理解和解决此类问题的思路。样例输入和输出展示了问题的具体应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:
输入正整数a,b,c,输出a/b的小数形式,精确到小数点后c位。其中a,b ≤ 106, c≤100。输入包含多组数据,结束标记为a=b=c=0。
样例输入:
1 6 4
0 0 0
样例输出:
Case 1 : 0.1667

此题与书上例题2-6 数据统计2 相似,以 0 为输入结束标记,难点在于 “精确到小数点后c位”。

方法一:
用%.*lf ,这是我们比较容易想到的

#include <stdio.h>
int main()
{
   
   
	long long a,b;
    int c,count = 1;
    while (scanf("%lld %lld %d",&a,&b,&c)== 3&&(a!=0&&b!=0&&c!=0))
    {
   
   
        printf("Case %d : %.*lf\n",count++,c,(double)a/b);
        /*  %*.*lf 前面的.定义总的宽度,后面的*指输出几位小数  */ 
    }
    return 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Simone Zeng

给作者来杯咖啡吧~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值