C语言例题——计算三角形的面积(通过边长或者顶点)

  • 通过边长计算三角形的面积
    科普时间,这里需要用到海伦公式:

假设在平面内,有一个三角形,边长分别为a、b、c,三角形的面积S可由以下公式求得:
在这里插入图片描述
而公式里的p为半周长(周长的一半)。
在这里插入图片描述

#include "stdio.h"
#include "math.h"

void main() {
    //输入三角形的三个边计算三角形的面积
    double a, b, c, area, p;
    printf("请输入三角形的三个边长");
    //%lf代表双精度浮点型数据
    scanf("%lf%lf%lf", &a, &b, &c);
    //判断输入的值是否构成三角形,如果任意两边和大于第三个边,计算面积
    if (a + b > c && a + c > b && b + c > a) {
        p = (a + b + c) / 2.0;
        //sqrt()返回某个数的平方根
        area = sqrt(p * (p - a) * (p - b) * (p - c));
        printf("三角形面积是:%.2lf", area);
    } else {
        printf("无法构成三角形");
    }

}
  • 通过输入三角形的三个顶点计算三角形的面积
    和上面直接输入三角形的三个边长相比,这里只是多了一步求边长,用到我们高中学到的两点间的距离公式,其余步骤相同。
#include "stdio.h"
#include "math.h"


void main() {

    int x1, y1, x2, y2, x3, y3;
    double a, b, c, p, area;

    printf("请输入第1个点的坐标:");
    scanf("%d%d", &x1, &y1);

    printf("请输入第2个点的坐标:");
    scanf("%d%d", &x2, &y2);

    printf("请输入第3个点的坐标:");
    scanf("%d%d", &x3, &y3);

    //计算三个边的长度,点与点之间的距离  pow(double x, double y) 返回x 的y 次幂
    a = sqrt(pow(x1 - x2, 2) + pow(y1 - y2, 2));
    b = sqrt(pow(x1 - x3, 2) + pow(y1 - y3, 2));
    c = sqrt(pow(x2 - x3, 2) + pow(y2 - y3, 2));

    //和上面一样
    if (a + b > c && a + c > b && b + c > a) {
        p = (a + b + c) / 2.0;
        //sqrt()返回某个数的平方根
        area = sqrt(p * (p - a) * (p - b) * (p - c));
        printf("三角形面积是:%.2lf", area);
    } else {
        printf("输入的三个点无法构成三角形");

    }

}
	

初学C语言,如有错误,还望指正,因考试需要,代码运行环境为:
在这里插入图片描述
不同编译器和不同版本C语言代码略有不同。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鑫宇_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值