来源:"蓝桥杯"练习系统
资源限制:
时间限制:1.0s 内存限制:256.0MB
问题描述:
我们知道,整数做除法时,有时得到有限小数,有时得到无限循环小数。如果我们把有限小数的末尾加上无限多个0,它们就有了统一的形式。本题的任务是:在上面的约定下,求整数除法小数点后的第n位开始的3位数。
输入格式:
一行三个整数:a b n,用空格分开。a是被除数,b是除数,n是所求的小数后位置(0<a,b,n<1000000000)
输出格式:
一行3位数字,表示:a除以b,小数后第n位开始的3位数字。
样例输入
1 8 1
样例输出
125
样例输入
1 8 3
样例输出
500
样例输入
282866 999000 6
样例输出
914
思考:
很有意思的求小数的题目,基础训练上有很多关于小数计算的,但是真正的试题里面少。对于小数的处理可以详见代码,核心思想和数学除法一样,不足的补零。对于求解数组变大的解决方法,我采用了一个小技巧,可以快速解决该题,由于输出只有三位,可以使用i%n的方法,数组循环存储n个数字,到时候输出即可。
代码:
#include<iostream>
#include<cstring>
#include<vector>
#include<algorithm>
#include<cmath>
using namespace std;
int a,b,n;
int s[20];
int main()
{
cin>>a>>b>>n;
int t=a/b;
if(t!=0) a-=t*b;//a只剩下除下来小数的部分
for(int i=1;i<n+3;i++)
{
a*=10;
int t=a/b;
s[i%10]=t;
a-=t*b;
if(i>=n) cout<<s[i%10];
}
return 0;
}