标签:10 gcd int 数据 军队 read 队伍 解题 CJOJ
题面
【问题描述】
给定一个有 n 个队伍的人组成的序列,第 i 个队伍 i 有 s[i]个人组成,一个 l 到 r 的子序
列是合法的,当且仅当((∀i)(∀j)∧(i≠j)∧(l≤i,j≤r))→(gcd(s[i],s[j])=1),即对于该序列中任两个
不相同的队伍,他们人数的最大公约数为 1,并且要求该子序列的总人数大于等于 k。
且由于每个队伍能够审批携带的仪器是有限的,所以需要这个队伍(r - l + 1)尽可能长,
请求出这个队伍的最长长度,若不存在,请输出 0。
【输入】
第一行两个整数 n,k 分别表示队伍数量和人数下限
接下来一行 n 个整数,表示每个队伍的人数
【输出】
一行一个整数,表示队伍的最长长度,如果不存在一个这样的队伍,则输出 0
【输入输出样例】
Input
5 14
4 5 12 3 2
Output
2
【数据范围】
对于 10%的数据 n≤10
对于另外 20%的数据 n≤100
对于另外 20%的数据 n≤2∗1000
对于全部的数据 1≤n≤10^5, 1≤s[i]≤10^6, k≤ int。
题解
n^3log直接过??
数据水的没话说肯定是tham出的数据
代码
#include <cstdio>
#define ll long long
#define file(x) freopen(x".in","r",stdin);freopen(x".out","w",stdout);
using namespace std;
inline int read(){
int x=0,f=1;char c=getchar();
while (c>'9'||c<'0') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') {x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x*f;
}
const int maxn=1e5+5;
int n,k;
int s[maxn];
int ans[maxn],anss;
int max(int a,int b){return a>b?a:b;}
inline int gcd(int a,int b) {return b==0?a:gcd(b,a%b);}
void init(){
n=read(),k=read();
for (int i(1);i<=n;++i) s[i]=read();
}
void doit(){
for (int i(1);i<=n;++i){
for (int j(i+1);j<=n;++j){
int flag=1;
if (gcd(s[j],s[i])==1){
for (int k(i+1);k<j;k++)
if (gcd(s[j],s[k])!=1) {j=n;flag=0;break;}
}
else break;
if (flag) ans[i]++;
else break;
}
}
for (int i(1);i<=n;++i) anss=max(anss,ans[i]);
printf("%d\n",anss+1);
}
signed main(){
file("tarmy");
init();
doit();
return 0;
}
标签:10,gcd,int,数据,军队,read,队伍,解题,CJOJ
来源: https://www.cnblogs.com/ancer/p/11294821.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。