给定平面上任意三个点的坐标,检验它们能否构成三角形。

#include <stdio.h>
#include <stdlib.h>
#include<math.h>

int main()
{
    float x1,y1,x2,y2,x3,y3;
    float i,j,k;
    float s,d,f;
    scanf("%f %f %f %f %f %f",&x1,&y1,&x2,&y2,&x3,&y3);
    i=sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1));
    j=sqrt((x3-x2)*(x3-x2)+(y3-y2)*(y3-y2));
    k=sqrt((x3-x1)*(x3-x1)+(y3-y1)*(y3-y1));
    if(i+j<=k||i+k<=j||j+k<=i)
        printf("Impossible");
    else
    {
        s=i+j+k;
        f=s/2;
        d=sqrt(f*(f-i)*(f-j)*(f-k));
        printf("L = %.2f, A = %.2f",s,d);
    }
    return 0;
}

PTA3-5 三角形判断,总是显示输入为实数时候答案错误,不知道哪里错了。

输入格式:

输入在一行中顺序给出六个[−100,100]范围内的数字,即三个点的坐标x​1​​、y​1​​、x​2​​、y​2​​、x​3​​、y​3​​。

输出格式:

若这3个点不能构成三角形,则在一行中输出“Impossible”;若可以,则在一行中输出该三角形的周长和面积,格式为“L = 周长, A = 面积”,输出到小数点后2位。

查看全部
kskky888
kskky888
2020/11/28 17:23
  • c语言
  • 点赞
  • 收藏
  • 回答
    私信

1个回复