三角形的类型判别

三角形的类型判别,其中运用海伦公式求三角形面积,下面给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代码运行结果如下:
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代码运行结果如下:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值