问题 C: Cly的三角形

题目描述

Cly很喜欢三角形,有一天他遇到了一道和三角形有关的题,但是这道题他简单了,他懒得做,于是交给了你。
给定一个数组,每次询问一个子区间,如果能从这个子区间挑出三个数组成三角形输出clynb,否者输出clycdd。

输入

第一行给出数组大小n,查询次数q (1<=m,q<=1e5)
接下来一行输入n个数,表示a[i] (1<=a[i]<=1e9)
接下来q行,每行输入两个数l,r,代表一个子区间 (1<=l,r<=n)

输出

对于每个询问输出clynb或者clycdd

样例输入

5 3
2 1 4 3 5
1 2
1 3
3 5

样例输出

clycdd
clycdd
clynb

看了题之后的第一反应是分这么几步。
1:判断l—r区域内是否有大于等于三个数字,没有就输出clycdd。
2:把数据sort一遍从小到大排序。
3:从第一个到第n-2个开始遍历,判断a[i]+a[i+1]>a[i+2]是否成立,成立就输出clynb,全不成立就输出clycdd。
4:提交,超时,卒…

赛后看了题解才明白,我们都知道(除了我)斐波那契数列递推式是a[i]+a[i+1]=a[i+2],第44项为七亿多,第45项就十亿多了了。题目中
如果这个数列不满足形成三角形的条件不能形成三角形的条件是a[i]+a[i+1]<=a[i+2],我们就让a[i]+a[i+1]=a[i+2],这样就会形成斐波那契数列。然后根据题目中a[i]的范围在1e9之内我们可以推出:从第45项开始知数列不满足a[i]=a[i-1]+a[i-2],此时必能形成三角形。于是我们给题目优化一下,当l—r的长度大于45时,就一定是clynb,这样一来就能少判断好多数据,时间上也不会超辣~

#include <bits/stdc++.h>
using namespace std;
#define qc std::ios::sync_with_stdio(0);
const int N = 1e5 + 10;
long long a[N];
long long b[N];

int main() {
	int n, q;
	scanf("%d%d", &n, &q);
	for (int i = 1; i <= n; i++) {
		scanf("%lld", &a[i]);
	}
	while (q--) {
		int l, r;
		scanf("%d%d", &l, &r);
		int len = r - l + 1;
		if (len <= 2)
			printf("clycdd\n");
		else if (len >= 45) {
			printf("clynb\n");
		} else {
			for (int i = 0; i < len; i++) {
				b[i] = a[i + l];
			}
			sort(b, b + len);
			int flag = 0;
			for (int i = 0; i < len - 2; i++) {
				if (b[i] + b[i + 1] > b[i + 2]) {
					printf("clynb\n");
					flag = 1;
					break;
				}
			}
			if (flag == 0)
				printf("clycdd\n");
		}
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值