第1节 基础-圆周率
计算机大牛们都在拼算法,计算圆周率小数点后面的第n位。这涉及到许多除法,现在给你一个被除数和除数,请你计算小数点后n位的值。
输入描述:
输入包含多组数据。每组数据包含三个正整数:被除数a和除数b(1≤a<b≤100),以及精度n(1≤n≤1000)。
输出描述:
对应每组数据,输出a/b的结果,小数后面保留n位(不到n位的补零)。
示例1
输入
1 2 5 2 3 3
输出
0.50000 0.666
不得不吐槽下题目给的数据真的特别水,什么是模拟除法,这个我想了很久,看别人的代码也不是很懂,最终还是看懂了,自己真的有点笨啊。首先这样想20/3怎样进行运算,20/3=6,20%3=2是吧,接下来的操作就是2*10/3=6,这个是不不好理解,其实你就自己想一想,自己列一个20/3的式子,就能理解.主要是代码的实现过程.
#include<iostream>
#include<algorithm>
#include<cstdio>
using namespace std;
int main()
{
int a,b,n;
while(scanf("%d%d%d",&a,&b,&n)!=EOF)
{
printf("%d.", a/b);//这里一定要注意不是%0.多少
for(int i=1;i<=n;i++)//循环1到n次,保留n位有效数字
{
a=a%b;//例如20%3=2
a=a*10;//2*10=20
printf("%d",a/b);//输出6
}
printf("\n");
}
return 0;
}
应该能看懂.谢谢阅读.