蓝桥杯:BASIC-03——圆的面积

该博客介绍了一个C++程序,用于根据给定的半径计算圆的面积。程序中定义了π的值并使用pow函数计算平方,然后按照指定的精度(小数点后7位)输出结果。博客强调了在实数输出时保持精度的重要性,并提供了浮点数和双精度数的精度概念。
摘要由CSDN通过智能技术生成

问题描述

给定圆的半径r,求圆的面积。

输入格式

输入包含一个整数r,表示圆的半径。

输出格式

输出一行,包含一个实数,四舍五入保留小数点后7位,表示圆的面积。

说明:在本题中,输入是一个整数,但是输出是一个实数。

对于实数输出的问题,请一定看清楚实数输出的要求,比如本题中要求保留小数点后7位,则你的程序必须严格的输出7位小数,输出过多或者过少的小数位数都是不行的,都会被认为错误。

实数输出的问题如果没有特别说明,舍入都是按四舍五入进行。

样例输入

4

样例输出

50.2654825

数据规模与约定

1 <= r <= 10000。

提示

本题对精度要求较高,请注意π的值应该取较精确的值。你可以使用常量来表示π,比如PI=3.14159265358979323,也可以使用数学公式来求π,比如PI=atan(1.0)*4。

关键字:入门 实数输出 

#include<iostream>
#include<math.h>
#include<iomanip>
#define PI acos(-1)
using namespace std;


int main()
{
	int r;
	double s;
	cin>>r;
	
	s=PI*pow(r,2);
    //ios::fixed 将符点数按照普通定点格式处理(非科学计数法)
	cout<<setiosflags(ios::fixed)<<setprecision(7)<<s<<endl;
	return 0;
}

知识点:float和double

float:2^23 = 8388608,共七位,所以float的精度为6~7位有效数字;

double:2^52 = 4503599627370496,共16位,所以double的精度为15~16位有效数字。

float能保证6位。double能保证15位。

默认float和double都只能显示6位小数位。

在输出语句之前插入 setiosflags(ios::fixed)<<setprecision(7)  ( #include<iomanip> 强制输出小数位

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值