「2021年TYWZ普及模拟题」多边形 待定题解

文章目录

题目描述

一个凸多边形具有非常多优秀的性质,它的任意内角小于或等于 18 0 。 180^。 180。 。

小 F 将 n n n 条边交给小 Y, 询问小Y这 n n n 条边能否围成一个凸 n n n 边形,小 Y 当然知道这道题的答案,但是她决定用这个问题考考你。

输入格式

输入文件的第一行,包含一个正整数 T T T,表示有 T T T 组测试数据,每组数据包含两行。

每组数据的第一行包含一个正整数 n n n,表示给定 n n n 条边。

每组数据的第二行包含 n n n 个正整数 a 1 a 2 ... a_1 a_2 \dots a1a2... ... a n \dots a_n ...an,以空格隔开,表示 n n n 条边的长度。

输出格式

输出 T T T 行,每行输出YESNO,输出YES表示可以围成一个凸多边形,输出NO表示不可以围成一个凸多边形。

样例

样例输入 1

复制代码
2
3
3 4 5
3
2 7 3

样例输出 1

复制代码
YES
NO

样例输入 2

复制代码
2
4
1 2 3 4
4
8 2 3 3

样例输出 2

复制代码
YES
NO

数据范围与提示

样例 1 1 1 说明:

第一组数据中的三条边显然可以构成一个直角三角形,因为 3 × 3 + 4 × 4 = 5 × 5 3 \times 3+4 \times 4=5 \times 5 3×3+4×4=5×5。

第二组数据中的三条边无法构成一个三角形,应为三角形的任意两条边之和大于第三边,而 2 + 3 < 7 2+3 < 7 2+3<7。

前置知识

思路与部分实现

完整代码

cpp 复制代码
#include<iostream>
using namespace std;
int main()
{
    int t;
    scanf("%d",&t);
    while(t--){
        int n,x,maxn=-1,sum=0;
        scanf("%d",&n);
        while(n--){
            scanf("%d",&x);
            maxn=max(maxn,x),sum+=x;
        }
        if(sum-maxn>maxn)
        	printf("YES\n");
        else printf("NO\n");
    }
    return 0;
}

文章小结

相关推荐
DanyHope9 分钟前
《LeetCode 49. 字母异位词分组:哈希表 + 排序 全解析》
算法·leetcode·哈希算法·散列表
iAkuya12 分钟前
(leetcode) 力扣100 15轮转数组(环状替代)
数据结构·算法·leetcode
杰克尼14 分钟前
蓝桥云课-5. 花灯调整【算法赛】
java·开发语言·算法
.小墨迹15 分钟前
C++学习之std::move 的用法与优缺点分析
linux·开发语言·c++·学习·算法·ubuntu
wanghowie16 分钟前
01.02 Java基础篇|核心数据结构速查
java·开发语言·数据结构
努力学算法的蒟蒻22 分钟前
day38(12.19)——leetcode面试经典150
算法·leetcode·面试
看见繁华27 分钟前
C++ 设计模式&设计原则
java·c++·设计模式
点云SLAM30 分钟前
C++ error C2065: “M_PI”: 未声明的标识符 解决方案
开发语言·c++·error c2065·m_pi未声明 解决方案
搬砖魁首31 分钟前
ZK-ALU-在有限域上实现乘法和除法
算法·zk·alu·域运算·算术逻辑单元·模乘·蒙哥马利模约简
草莓熊Lotso37 分钟前
C++11 核心精髓:类新功能、lambda与包装器实战
开发语言·c++·人工智能·经验分享·后端·nginx·asp.net