cracker_03 2021-10-18 20:11 采纳率: 82.6%
浏览 39
已结题

用了三个for循环超时了呜呜,但是想不出其他方法来

Description

小Z的椅子坏了,动手能力超强的他准备自己来修理,他知道三角形具有稳定性,所以他想自己做一个三角形架子来支撑一下,于是他来到了地下室找了一堆木棍,他随机拿起三根,问这三根一定能组成一个三角形么?假设一共有n条木棍,现已知每条木棍的长度。

Input

输入数据有多组,先输入T,表示组数,接下每组包括两行,第一行行包括一个正整数n(3<=n<=2000),第二行包括n个正整数a1,a2,……,an

Output

对于每组数据输出包括一行,如果可以,输出Yes,否则No。

Sample Input

2
4
3 2 3 2
3
3 1 1
Sample Output

Yes
No



#include<stdio.h>
int main()
{
    int T;
    scanf("%d", &T);
    int a[2003];
    while (T--)
    {
        int n;
        scanf("%d", &n);
        for (int i = 0; i < n; i++)
        {
            scanf("%d", &a[i]);
        }
        int flag = 1;
        for (int i = 0; i < n; i++)
        {
            for (int j = i+1; j < n; j++)
            {
                for (int k = j+1; k < n; k++)
                {
                    if (!(a[i]+a[j]>a[k]&&a[i]+a[k]>a[j]&&a[k]+a[j]>a[i]))
                    {
                        flag = 0;
                    }
                }
            }
        }
        if (flag)
        {
            printf("Yes\n");
        }
        else
        {
            printf("No\n");
        }
    }
    return 0;
}

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2021-10-18 20:57
    关注

    这么改下,试试:

    #include<stdio.h>
    int main()
    {
        int T;
        scanf("%d", &T);
        int a[2003];
        while (T--)
        {
            int n;
            scanf("%d", &n);
            for (int i = 0; i < n; i++)
            {
                scanf("%d", &a[i]);
            }
            int flag = 1;
            for (int i = 0; i < n; i++)
            {
                for (int j = i+1; j < n; j++)
                {
                    for (int k = j+1; k < n; k++)
                    {
                        if (!(a[i]+a[j]>a[k]&&a[i]+a[k]>a[j]&&a[k]+a[j]>a[i]))
                        {
                            flag = 0; break;
                        }
                    }
                    if(!flag) break;
                }
                if(!flag) break;
            }
            if (flag)
            {
                printf("Yes\n");
            }
            else
            {
                printf("No\n");
            }
        }
        
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月5日
  • 已采纳回答 10月28日
  • 创建了问题 10月18日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。