【问题描述】
已知三角形的三个顶点的坐标,求该三角形的面积。
【输入形式】
有多组测试数据。
每组测试数据占一行,6个用空格分隔开的浮点数:x1,y1,x2,y2,x3,y3。表示三角形三个顶点的坐标。
一行6个0(形如0 0 0 0 0 0),表示输入结束,并且不需要处理。
40%的顶点坐标 -10 ≤ xi,yi≤ 10;i=1,2,3
30%的顶点坐标 -100 ≤ xi,yi≤ 100;i=1,2,3
20%的顶点坐标 -1000 ≤ xi,yi≤ 1000;i=1,2,3
10%的顶点坐标 -10000 ≤ xi,yi≤ 10000;i=1,2,3
【输出形式】
对于每组测试数据,输出对应三角形面积,保留小数点后6位。
【样例输入】
1 2 3 4 -2 8 0 0 0 1 1 0 0 0 0 0 0 0
【样例输出】
9.000000 0.500000
#include <iostream>
#include <string>
#include <algorithm>
#include <cmath>
#include<iomanip>//保留小数位数
//#include<bits/stdc++.h> 万能头文件
using namespace std;
double mmid(double,double,double);
int main() {
double x1,x2,x3;
double y1,y2,y3;
while(1) {
cin>>x1>>y1>>x2>>y2>>x3>>y3;
if(x1==0&&x2==0&&x3==0&&y1==0&&y2==0&&y3==0)break;//老老实实加上判断条件
double S;
S=abs(x1*y2+x2*y3+x3*y1-x1*y3-x2*y1-x3*y2)/2;//向量的叉乘
cout<<fixed<<setprecision(6)<<
S<<endl;
}
return 0;
}
//三角形面积公式 用行列式计算
//S=|x1 y1 1 | 用这个公式计算
// |x2 y2 1 |
// |x3 y3 1|