上文链接:蓝桥杯之Fibonacci数列
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给定圆的半径r,求圆的面积。
输入格式
输入包含一个整数r,表示圆的半径。
输出格式
输出一行,包含一个实数,四舍五入保留小数点后7位,表示圆的面积。
说明:在本题中,输入是一个整数,但是输出是一个实数。
对于实数输出的问题,请一定看清楚实数输出的要求,比如本题中要求保留小数点后7位,则你的程序必须严格的输出7位小数,输出过多或者过少的小数位数都是不行的,都会被认为错误。
实数输出的问题如果没有特别说明,舍入都是按四舍五入进行。
样例输入
4
样例输出
50.2654825
数据规模与约定
1 <= r <= 10000。
代码展示
#include <iostream>
#include <cmath>//引入cmath提供反正切函数及幂方函数
#include <iomanip>//引入高精度设置
using namespace std;
int main()
{
double r,s,pi = atan(1.0)*4;//定义半径r,面积s,π值pi
cin>>r;
s = pi*pow(r,2);
cout.setf(ios::fixed);
cout<<fixed<<setprecision(7)<<s<<endl;//设置输出位数7位
return 0;
}
该算法之我的总结
- 不使用printf("%.6f",s)格式化位数是因为不如setprecision精度高,详情参考菜鸟教程:c语言教程
- 注意double是否满足最大数据规模,本题中满足。若不满足则需要更换更高精度关键字或者使用数组方式求解。