1571: Subarray GCD
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 90 Solved: 48
[ Submit][ Status][ Web Board]
Description
Given an array A1,A2...AN, you have to print the size of the largest contiguous subarray such that
GCD of all integers in that subarray is 1.
Formally,
For a subarray Ai,Ai+1...Aj where 1 ≤ i < j ≤ N to be valid: GCD(Ai,Ai+1...Aj) should be 1. You have to print the size of the largest valid subarray.
If no valid subarray exists, output -1.
Note:A single element is not considered as a subarray according to the definition of this problem.
Input
First line contains T, the number of testcases. Each testcase consists of N in one line followed by Nintegers in the next line.
Constraints
- 1 ≤ T ≤ 10
- 2 ≤ N ≤ 105
- 1 ≤ Ai ≤ 105
Output
For each testcase, print the required answer in one line.
Sample Input
Sample Output
#include<algorithm>
#include<string.h>
#include<stdio.h>
using namespace std;
int gcd(int a,int b)
{
while(b)//辗转相减法
{
int temp=a%b;
a=b;
b=temp;
}
return a;
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n;
scanf("%d",&n);
int x;
scanf("%d",&x);
for(int i=1;i<n;i++)
{
int temp;
scanf("%d",&temp);
x=gcd(x,temp);
}
if(x==1)
printf("%d\n",n);
else
printf("-1\n");
}
return 0;
}