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

    根据输入的三角形的三条边判断三角形的类型,并输出它的面积和类型。 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 条评论
登录 后参与评论

相关文章

来自专栏数据结构与算法

计数排序

算法思想 编辑 计数排序对输入的数据有附加的限制条件: 1、输入的线性表的元素属于有限偏序集S; 2、设输入的线性表的长度为n,|S|=k(表示集合S中元素...

28910
来自专栏Vamei实验室

Python补充05 字符串格式化 (%操作符)

在许多编程语言中都包含有格式化字符串的功能,比如C和Fortran语言中的格式化输入输出。Python中内置有对字符串进行格式化的操作%。 模板 格式化字符串时...

2039
来自专栏数据结构与算法

P1062 数列

题目描述 给定一个正整数k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是: 1,3,4,9,...

2757
来自专栏数据结构与算法

P3372 【模板】线段树 1 区间查询与区间修改

题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.求出某区间每一个数的和 输入输出格式 输入格式: 第一行包含两个...

2956
来自专栏数据结构与算法

1341 与3和5无关的数

1341 与3和5无关的数 时间限制: 1 s 空间限制: 64000 KB 题目等级 : 白银 Silver 题目描述 Description ...

2664
来自专栏赵俊的Java专栏

搜索插入位置

1171
来自专栏用户2442861的专栏

NumPy简明教程(二、数组1)

http://blog.csdn.net/sunny2038/article/details/9002531

491
来自专栏Python爬虫与算法进阶

说一道排序题

关于Python的sorted排序算法,这篇文章讲的比较详细:python sort函数内部实现原理,说到Python使用的是著名的Timesort算法。

472
来自专栏深度学习之tensorflow实战篇

python高阶函数:map(f,[list]),reduce(f,[list],可选初始值),

map,reduce和filter三个函数在python3和python2中发生了较大的差异。具体请看文章后面部分。 1. python的map()函数 ...

3104
来自专栏数据结构与算法

P3373 【模板】线段树 2 区间求和 区间乘 区间加

题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输...

36111

扫码关注云+社区