传送门: 总体思路很流畅,就是代码不怎么好写
思路题目要求两个操作 :
- 区间更新 : 懒标记 (难写啊!
- 区间查询 : 查询 g c d gcd gcd更不好写!
区间更新的优化 :
区间 + + + 或者 − - − 一个数 可以用 差分 变成单点操作
区间查询优化 :
根据 g c d ( a , b ) = g c d ( a , b − a ) . . . . . g c d ( a , b , c , d . . . ) = g c d ( a , b − a , c − b , . . . ) gcd(a,b) = gcd(a,b-a)..... gcd(a,b,c,d...) = gcd(a,b-a,c-b,...) gcd(a,b)=gcd(a,b−a).....gcd(a,b,c,d...)=gcd(a,b−a,c−b,...)
公式请拐弯到y总视频
因此我们只需要特殊处理 第一个点 和 后面用 差分处理 即可
CODE#include
using namespace std;
#define ll long long
#define ned '\n'
const int N = 5e5+10;
int n,m;
ll w[N];
struct node
{
int l,r;
ll sum,d;
} tr[N*4];
void pushup(node &u,node &l,node &r)
{
u.sum = l.sum + r.sum;
u.d = __gcd(l.d,r.d);
}
void pushup(int u)
{
pushup(tr[u],tr[u
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?