三角形的类型判别,其中运用海伦公式求三角形面积,下面给c和python代码。
c代码:
//三角形类型判别
#include <stdio.h>
#include <stdlib.h>
#include <math.h> //sqrt
void main(void)
{
int a,b,c;
float p,area;
printf("请输入三角形三条边的长度:");
scanf("%d,%d,%d",&a,&b,&c);
if((a + b > c) && (a + c > b) && (b + c > a))
{
printf("能构成三角形\n");
/* 海伦公式求三角形面积 S=√[p(p-a)(p-b)(p-c)] 而公式里的p为半周长:p=(a+b+c)/2 */
p = (a + b + c) / 2;
area = (float)sqrt(p * (p - a) * (p - b) * (p - c));
printf("三角形的面积为%f\n",area);
if((a == b) && (b == c))
printf("您输入的三角形为等边三角形\n");
else if((a == b) || (b == c) ||(a == c))
printf("您输入的三角形为等腰三角形\n");
else if((a^2 + b^2 ==c^2) || (a^2 + c^2 ==b^2) || (b^2 + c^2 ==a^2))
printf("您输入的三角形为直角三角形\n");
else
printf("您输入的三角形为普通三角形\n");
}
else
printf("不能构成三角形\n");
system("pause");
}
c代码运行结果如下:
python代码:
import math as m
side_lengths = input("请输入要查询的三角形的三个边的大小,例如:2,2,2\n")
length = len(side_lengths)
flag = 0
p = 0
for i in range(0,length):
if side_lengths[i] == ',':
flag += 1
if flag == 1:
a = i
if flag == 2:
b = i
a_length = float(side_lengths[:a])
b_length = float(side_lengths[a+1:b])
c_length = float(side_lengths[b+1:])
if((a_length + b_length > c_length) &
(b_length + c_length > a_length) &
(a_length + c_length > b_length)):
print("能构成三角形")
p = (a_length + b_length + c_length)/2
area = m.sqrt(p * (p - a_length) * (p - b_length) * (p - c_length))
print("三角形的面积为%f"%area)
if ((a_length == b_length) & (b_length == c_length) & (a_length == c_length)):
print("你输入的为等边三角形")
elif((a_length == b_length) | (b_length == c_length) | (a_length == c_length)):
print("你输入的为等腰三角形")
elif ((a_length * a_length + b_length * b_length == c_length * c_length) |
(a_length * a_length + c_length * c_length == b_length * b_length) |
(b_length * b_length + c_length * c_length == a_length * a_length)):
print("你输入的为直角三角形")
else:
print("不能构成三角形")
python代码运行结果如下: