蓝桥杯之圆的面积(c++实现)

上文链接:蓝桥杯之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是否满足最大数据规模,本题中满足。若不满足则需要更换更高精度关键字或者使用数组方式求解。

下文链接:蓝桥杯之十六进制转八进制极度简化版(c++代码实现)

发布了30 篇原创文章 · 获赞 3 · 访问量 2778

猜你喜欢

转载自blog.csdn.net/weixin_44077556/article/details/104169362