YTU OJ 1058: 三角形面积

52 篇文章 1 订阅

Description

三角形面积=SQRT(S*(S-a)*(S-b)*(S-c)) 其中S=(a+b+c)/2,a、b、c为三角形的三边。定义两个带参的宏,一个用来求area,另一个宏用来求S。 写程序,在程序中用带实参的宏名来求面积area。

Input

a b c三角形的三条边,可以是小数。

Output

三角形面积,保留3位小数

Sample Input

3 4 5

Sample Output

6.000

HINT

 主函数已给定如下,提交时不需要包含,会自动添加到程序尾部



/* C++代码 */


int main()

{

    float a,b,c,s,area;

    cin>>a>>b>>c;

    s=SSS(a,b,c);

    area=AQRT(a,b,c);

    cout<<setiosflags(ios::fixed);

    cout<<setprecision(3);

    cout<<area<<endl;

    return 0;

}

Source


【AC代码】

#include <iostream>
#include <iomanip>
#include <math.h>
using namespace std;
#define SSS(a,b,c) (a+b+c)/2;
#define AQRT(a,b,c) sqrt(s*(s-a)*(s-b)*(s-c));
int main()
{
    float a,b,c,s,area;
    cin>>a>>b>>c;
    s=SSS(a,b,c);
    area=AQRT(a,b,c);
    cout<<setiosflags(ios::fixed);
    cout<<setprecision(3);
    cout<<area<<endl;
    return 0;
}

【解析】

流的格式化。setiosflags(ios::fixed)将流的格式设置为:fixed(将一个浮点数表示为一个定点整数和小数点和小数部分的格式)。然后setprecision(3)表示小数部分的精度为3位。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值