第七天、判断三角形的类型

    根据输入的三角形的三条边判断三角形的类型,并输出它的面积和类型。 C代码:

/*第七天、判断三角形的类型*/
#include <stdio.h>
#include <stdlib.h>
#include <math.h> //sqrt
/*判断能否构成三角形公式:a+b>c;b+c>a;c+a>b三个式子都符合就能构成三角形*/
/*求面积,海伦公式:海伦公式:√[p(p-a)(p-b)(p-c) ]其中p=1/2(a+b+c)*/
/*三角形类型:等边三角形、等腰三角形、直角三角形、普通三角形*/
void main(void)
{
    int a,b,c;
    float p,area;
    printf("请输入要查询的三角形的三个边的大小,例如:2,2,2\n");
    scanf("%d,%d,%d",&a,&b,&c);
    if((a + b > c) && (b + c > a) && (c + a > b))
    {
        printf("能构成三角形\n");
        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) || (c == a))
            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");
}

结果显示:

python3.4.4代码:

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) \
   & (c_length + a_length > b_length)):
    print('能构成三角形')#后面不用加\n自动换行
    p = sum([a_length,b_length,c_length]) // 2  #注意:sum的参数是一个list
    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)):
        print('您输入的三角形为等边三角形')
    elif((a_length == b_length) | (b_length == c_length) | \
         (c_length == a_length)):
        print('您输入的三角形为等腰三角形')
    elif((a_length * a_length + b_length * b_length == c_length * c_length)\
         | (c_length * c_length + b_length * b_length == a_length * a_length)\
         | (a_length * a_length + c_length * c_length == b_length * b_length)):
        print('您输入的三角形为直角三角形') 
    else:
        print('您输入的三角形为普通三角形')
else:
    print('不能构成三角形')

input()

结果显示:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏懒人开发

(3.6)James Stewart Calculus 5th Edition:Implicit Differentiation

例如: x^2 + y^2 = 25 这个时候,我们知道 如果是函数, 用竖线检测, 需要把图像拆分

764
来自专栏wym

opencv学习笔记--ROI与泛洪填充

官方定义为:floodFill(InputOutputArray image, Point seedPoint, Scalar newVal, Rect* re...

582
来自专栏程序生活

斯坦福tensorflow教程-tensorflow 实现线性回归代码结果

1022
来自专栏Echo is learning

矩阵求导 -- 机器学习常用

1705
来自专栏应兆康的专栏

“西瓜书”——第三章_线性模型(笔记)

线性模型形式简单、易于建模,许多功能更为强大的非线性模型可在线性模型的基础上通过引入层级结构或高维映射而得。 ? ? ? ? ?

37015
来自专栏CreateAMind

Wasserstein GAN:GAN稳定训练的突破

In no experiment did we see evidence of mode collapse for the WGAN algorithm.

771
来自专栏数据派THU

从零开始用Python构造决策树(附公式、代码)

? 来源:Python中文社区 作者:weapon 本文长度为700字,建议阅读5分钟 本文介绍如何不利用第三方库,仅用python自带的标准库来构造一个决策...

2338
来自专栏一直在跳坑然后爬坑

深入理解向量进行矩阵变换的本质

向量的理解 上图表述的是平面上一点,在以i和j为基的坐标系里的几何表示,这个点可以看作(x,y)也可以看作是向量ox与向量oy的和。

794
来自专栏IT派

【深度学习入门系列】TensorFlow训练线性回归

作者:董超 来源:腾讯云技术社区「腾云阁」 上一篇文章我们介绍了 MxNet 的安装,但 MxNet 有个缺点,那就是文档不太全,用起来可能是要看源代码才能理...

3133
来自专栏MelonTeam专栏

深度学习入门实战(二)

导语:上一篇文章我们介绍了MxNet的安装,但MxNet有个缺点,那就是文档不太全,用起来可能是要看源代码才能理解某个方法的含义,所以今天我们就介绍一下Te...

19910

扫码关注云+社区