Codeforces 892 C. Pride (枚举)

网友投稿 596 2022-10-03

Codeforces 892 C. Pride (枚举)

Codeforces 892 C. Pride (枚举)

Description

You have an array a with length n, you can perform operations. Each operation is like this: choose two adjacent elements from a, say x and y, and replace one of them with gcd(x, y), where gcd denotes the greatest common divisor.What is the minimum number of operations you need to make all of the elements equal to 1?

Input

The first line of the input contains one integer n (1 ≤ n ≤ 2000) — the number of elements in the array.The second line contains n space separated integers a1, a2, …, an (1 ≤ ai ≤ 10^9) — the elements of the array.

Output

Print -1, if it is impossible to turn all numbers to 1. Otherwise, print the minimum number of operations needed to make all numbers equal to 1.

Examples input

52 2 3 4 6

Examples output

5

题意

给定一个数列,我们定义一个操作是取相邻的两个数计算其 gcd ,然后替换掉其中的某一个数,问最少多少步可以将数列全部变为 1 。

思路

显然,数列所有数的 gcd 如果不等于 1 答案一定是 -1 。

对于其他情况,我们枚举找出最短的 gcd 为 1 的区间,此时的操作即,先造出一个 1 ,然后用这一个 1 与相邻的数字进行 gcd 填充。

注意特判 n = 1 的情况与数列中存在 1 的情况。

AC 代码

#include#define IO ios::sync_with_stdio(false);\ cin.tie(0);\ cout.tie(0);using namespace std;typedef __int64 LL;const int maxn = 2e5+10;LL a[maxn];int n;void solve(){ LL k = a[0],one = (a[0]==1); for(int i=1; i>n; for(int i=0; i>a[i]; solve(); return 0;}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:YTU 2391: 求素数
下一篇:怎么把gif放进小程序
相关文章

 发表评论

暂时没有评论,来抢沙发吧~