C语言 南阳理工ACM 67.三角形面积

来源:互联网 发布:名片设计软件免费版 编辑:程序博客网 时间:2024/05/23 14:24
#include<stdio.h>
#include<math.h>
int main()
{
int x1,y1,x2,y2,x3,y3,a,b,c;
double s;
while(scanf("%d%d%d%d%d%d",&x1,&y1,&x2,&y2,&x3,&y3)&&(x1||y1||x2||y2||x3||y3))
{
       a=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
  b=(x1-x3)*(x1-x3)+(y1-y3)*(y1-y3);
  c=(x2-x3)*(x2-x3)+(y2-y3)*(y2-y3);
  s=sqrt((sqrt(a)+sqrt(b)+sqrt(c))*(sqrt(a)+sqrt(c)-sqrt(b))*(sqrt(a)+sqrt(b)-sqrt(c))*(sqrt(b)+sqrt(c)-sqrt(a)))/4;//将sqrt函数统一写在这个式子里可以避免计算过程中产生的误差,若在上面将a,b,c开方带入计算面积s则误差较大,结果不正确
     printf("%.1f\n",s);
}
  return 0;
}