题意
你知道什么是“互质序列”吗?那就是所有数的最大公约数恰好为1的序列。
“互质序列”非常容易找到,但是我们可以尝试通过删除这个序列的一个非空连续子序列来扩大它的最大公约数。
现在给定一个长度为n的序列,你需要从中删除一个非空连续子序列,使得剩下至少2个数,令E为剩下数的最大公约数的期望值,S为合法的方案数,请计算E*S的值。因为这个值可能非常大,请对998244353取模输出。
3<=n<=100000,ai<=10^9
分析
月赛A掉的第二道题。
设f[i]表示前缀gcd,g[i]表示后缀gcd,考虑到一个数x最多求logx次gcd后就会变为1,所以f和g都最多只有logai个不同的取值,那么只要分段枚举就可以了。
代码
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace