描述
输入三角形三边长a,b,c(保证能构成三角形),输出三角形面积。
输入描述
一行三个用一个空格隔开的实数a,b,c,表示三角形的三条边长。
输出描述
输出三角形的面积,答案保留四位小数。
样例输入 1
3 4 5
样例输出 1
6.0000
提示
数据范围与提示:
1≤a,b,c≤10000
已知三角形三边a,b,c,则(海伦公式)(p=(a+b+c)/2)S=[p(p−a)(p−b)(p−c)]
代码如下:
#include <iostream>
#include <cmath>
#include <iomanip>
#include <cassert>
using namespace std;
int main()
{
double a, b, c;
cin >> a >> b >> c;
assert(a >= 1 && a <= 10000);
assert(b >= 1 && b <= 10000);
assert(c >= 1 && c <= 10000);
if (a+b > c && a+c > b && b+c > a)
{
double p = (a+b+c)/2.0;
double s = sqrt((double)((p*(p-a)*(p-b)*(p-c))));
cout << setiosflags(ios::fixed);
cout << setprecision(4) << s << endl;
}
else
{
cout << "side length a, b and c can't form a triangle" << endl;
return -1;
}
return 0;
}