欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

C语言下三角形面积的求法及点到直线的距离。

程序员文章站 2022-03-02 10:56:36
...

例题:已知三角形的三点 A(x,y,z)、B(x1,y1,z1)、C(x2,y2,z2),求三角形的面积及以A为顶点的高。

我们知道三角形的面积可以通过2个向量的叉积求出。通过3个点我们可以得到2个向量P(BA)、P1(BC);

三角形ABC的面积S:

S=P×P1={[(y2-y1)*(z-z1)-(z2-z1)*(y-y1)]^2+[(z2-z1)*(x-x1)-(x2-x1)*(z-z1)]^2+[(x2-x1)*(y-y1)-(y2-y1)*(x-x1)]^2}^0.5÷2。

三角形以A为顶点的高及点A到直线BC的距离H:

H=2S/BC=2*S/[(x2-x1)^2+(y2-y1)^2+(z2-z1)^2]^0.5。

使用C语言我们可以以下代码实现:

//三维坐标系三角形面积及点到直线距离的求法
#define POW(x) (x)*(x)
#include <stdio.h>
#include <math.h>
int main(int argc,char *argv[])
{
    double x = 100.0, y = 100.0, z = 100.0;
    double x1 = 100.0, y1 = 220.0, z1 = 50.0;
    double x2 = 500.0, y2 = 130.0, z2 = 150.0;
    double Area,H;
    Area= sqrt(POW((y2-y1)*(z-z1)-(z2-z1)*(y-y1))
              +POW((z2-z1)*(x-x1)-(x2-x1)*(z-z1))
              +POW((x2-x1)*(y-y1)-(y2-y1)*(x-x1)))/2;
    H= sqrt((POW((y2-y1)*(z-z1)-(z2-z1)*(y-y1))
            +POW((z2-z1)*(x-x1)-(x2-x1)*(z-z1))
            +POW((x2-x1)*(y-y1)-(y2-y1)*(x-x1)))
            /(POW(x2-x1)+POW(y2-y1)+POW(z2-z1)));
    printf("三角的面积= %8.3f",Area);
    printf("三角形的高(点A到直线BC的距离)= %8.3f",H);
    return 0;
}

当三角形位于二维坐标系时,我们可以看做z=0,该方法同样可以计算,但我们可以更加简化公式,将z=z1=z2=0带入得到新
的计算公式:
三角形ABC的面积S:

S=P×P1={[(x2-x1)*(y-y1)-(y2-y1)*(x-x1)]^2}^0.5÷2。

三角形以A为顶点的高及点A到直线BC的距离H:

H=2S/BC=2*S/[(x2-x1)^2+(y2-y1)^2]^0.5。
使用C语言我们可以以下代码实现:

//二维坐标系三角形面积及点到直线距离的求法
#define POW(x) (x)*(x)
#include <stdio.h>
#include <math.h>
int main(int argc,char *argv[])
{
    double x = 100.0, y = 100.0;
    double x1 = 100.0, y1 = 220.0;
    double x2 = 500.0, y2 = 130.0;
    double Area,H;
    Area= sqrt(POW((x2-x1)*(y-y1)-(y2-y1)*(x-x1)))/2;
    H= sqrt(POW((x2-x1)*(y-y1)-(y2-y1)*(x-x1))
            /(POW(x2-x1)+POW(y2-y1)));
    printf("三角的面积= %8.3f",Area);
    printf("三角形的高(点A到直线BC的距离)= %8.3f",H);
    return 0;
}


 

相关标签: C语言