1034:计算三角形面积

1034:计算三角形面积


时间限制: 1000 ms         内存限制: 65536 KB
提交数: 122471     通过数: 41665

【题目描述】

平面上有一个三角形,它的三个顶点坐标分别为(x1,y1),(x2,y2),(x3,y3),那么请问这个三角形的面积是多少,精确到小数点后两位。

【输入】

输入仅一行,包括6个单精度浮点数,分别对应x1,y1,x2,y2,x3,y3

【输出】

输出也是一行,输出三角形的面积,精确到小数点后两位。

【输入样例】

0 0 4 0 0 3

【输出样例】

6.00

【思路分析】

  1. 读入三个顶点坐标(x1, y1), (x2, y2), (x3, y3)。
  2. 根据三个顶点坐标计算三条边的长度,分别为a, b, c,其中,
    a = sqrt((x1-x2)^2 + (y1-y2)^2)
    b = sqrt((x2-x3)^2 + (y2-y3)^2)
    c = sqrt((x1-x3)^2 + (y1-y3)^2)
  3. 计算半周长q,即 q = (a + b + c)/2。
  4. 计算三角形的面积s,即 s = sqrt(q * (q-a) * (q-b) * (q-c))。
  5. 输出面积s,保留两位小数。

 【示例代码】

#include<bits/stdc++.h>
using namespace std;
int main()
{
// 读入三个顶点坐标
double xa, ya, xb, yb, xc, yc;
cin >> xa >> ya >> xb >> yb >> xc >> yc;
// 计算三条边的长度
double a = sqrt((xa - xb) * (xa - xb) + (ya - yb) * (ya - yb));
double b = sqrt((xb - xc) * (xb - xc) + (yb - yc) * (yb - yc));
double c = sqrt((xa - xc) * (xa - xc) + (ya - yc) * (ya - yc));

// 计算半周长
double q = (a + b + c) / 2;

// 计算三角形的面积
double s = sqrt(q * (q - a) * (q - b) * (q - c));

// 输出面积,保留两位小数
printf("%.2lf", s);
}
return 0;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值