牛客网 圆周率(模拟除法)

第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;
}

应该能看懂.谢谢阅读.

猜你喜欢

转载自blog.csdn.net/cjh1459463496/article/details/83388474