三角形の面積 = SQRT(S*(Sa)*(Sb)*(Sc)) ただし、S=(a+b+c)/2、a、b、c は三角形の 3 辺です。パラメーターを使用して 2 つのマクロを定義します。1 つは領域の検索に使用され、もう 1 つのマクロは S の検索に使用されます。プログラムを作成し、マクロ名と実際のパラメータを使用して領域を見つけます。
入力フォーマット
三角形 abc の 3 辺は小数にすることができます。
出力フォーマット
三角形の面積を小数点第3位まで
サンプル入力
コピー
3 4 5
サンプル出力
コピー
6.000
#include<iostream>
#include<iomanip>
#include<cmath>
using namespace std;
#define GetS(a,b,c) ((a+b+c)/2.0)
#define GetArea(a,b,c){\
float S=GetS(a,b,c);\
float area=sqrt(S*(S-a)*(S-b)*(S-c));\
cout << fixed << setprecision(3) << area;\
}
/*这个"\"放在宏定义函数句子的末尾,表示本句结束,以及其他*/
int main() {
float a, b, c;
cin >> a >> b >> c;
GetArea(a,b,c);
return 0;
}