acwing-246. 区间最大公约数(线段树+gcd)[通俗易懂]

acwing-246. 区间最大公约数(线段树+gcd)[通俗易懂]给定一个长度为 N 的数列 A,以及 M 条指令,每条指令可能是以下两种之一:C l r d,表示把 A[l],A[l+1],…,A[r] 都加上 d。Q l r,表示询问 A[l],A[l+1],…,A[r] 的最大公约数(GCD)。对于每个询问,输出一个整数表示答案。输入格式第一行两个整数 N,M。第二行 N 个整数 A[i]。接下来 M 行表示 M 条指令,每条指令的格式如题目描述所示。输出格式对于每个询问,输出一个整数表示答案。每个答案占一行。数据范围N≤500000,M≤1

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一个长度为 N 的数列 A,以及 M 条指令,每条指令可能是以下两种之一:

C l r d,表示把 A[l],A[l+1],…,A[r] 都加上 d。
Q l r,表示询问 A[l],A[l+1],…,A[r] 的最大公约数(GCD)。
对于每个询问,输出一个整数表示答案。

输入格式
第一行两个整数 N,M。

第二行 N 个整数 A[i]。

接下来 M 行表示 M 条指令,每条指令的格式如题目描述所示。

输出格式
对于每个询问,输出一个整数表示答案。

每个答案占一行。

数据范围
N≤500000,M≤100000,
1≤A[i]≤1018,
|d|≤1018

输入样例:
5 5
1 3 5 7 9
Q 1 5
C 1 5 1
Q 1 5
C 3 3 6
Q 2 4
输出样例:
1
2
4
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 5e5 + 10;
#define lson u << 1
#define rson u << 1 | 1
struct Node{ 
   
    int l,r;
    ll gcd,sum;
}trie[N * 4];
ll a[N],d[N];
int gcd(int a,int b){ 
   
    return b == 0 ? a : gcd(b, a % b);
}
void pushup(int u){ 
   
    trie[u].sum = trie[lson].sum + trie[rson].sum;
    trie[u].gcd = gcd(trie[lson].gcd,trie[rson].gcd);
}
void build(int u,int l,int r){ 
   
    if(l == r)trie[u] = { 
   l,r,d[l],d[l]};
    else{ 
   
        trie[u] = { 
   l,r};
        int mid = (l + r) >> 1;
        build(lson,l,mid);
        build(rson,mid + 1,r);
        pushup(u);
    }
}
void modify(int u,int x,ll y){ 
   
    if(trie[u].l == x && trie[u].r == x)trie[u].sum += y,trie[u].gcd += y;
    else{ 
   
        int mid = (trie[u].l + trie[u].r) >> 1;
        if(x <= mid)modify(lson,x,y);
        else modify(rson,x,y);
        pushup(u);
    }
}
Node query(int u,int l,int r){ 
   
    if(trie[u].l >= l && trie[u].r <= r){ 
   
        Node t;
        t.sum = trie[u].sum;
        t.gcd = trie[u].gcd;
    
        return t;
    }
    int mid = (trie[u].l + trie[u].r) >> 1;
    if(r <= mid)return query(lson,l,r);
    else if(l > mid)return query(rson,l,r);
    else{ 
   
        auto left = query(lson,l,r),right = query(rson,l,r);
        Node t;
        t.sum = left.sum + right.sum;
        t.gcd = gcd(left.gcd,right.gcd);
        return t;
    }
}

int main(){ 
   
    int n,m;
    cin>>n>>m;
    ios::sync_with_stdio(false);
    for(int i = 1;i <= n;i ++){ 
   
        cin>>a[i];
        d[i] = a[i] - a[i - 1];
    }
    build(1,1,n + 1);
    char t;
    ll x,y,dd;
    for(int i = 0;i < m;i ++){ 
   
        cin>>t>>x>>y;
        if(t == 'C')cin>>dd;
        if(x > y)swap(x,y);
        if(t == 'C'){ 
   
            modify(1,x,dd);
            modify(1,y + 1,-dd);
        }
        else{ 
   
            auto left = query(1,1,x),right = query(1,x + 1,y);
            cout<<gcd(left.sum,right.gcd)<<endl;
        }
    }
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168603.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 下午1:46
下一篇 2022年8月9日 下午2:00


相关推荐

  • 修改DeDe标签Pagelist分页样式,自定义分页样式

    修改DeDe标签Pagelist分页样式,自定义分页样式

    2021年9月21日
    47
  • linux权限777什么意思,chmod 权限777是什么意思

    linux权限777什么意思,chmod 权限777是什么意思chmod 权限 777 是什么意思在 Unix 和 Linux 的各种操作系统下 每个文件 文件夹也被看作是文件 都按读 写 运行设定权限 例如我用 llboa 命令列文件表时 得到如下输出 rwx xr x1rootroot 3117 20boa 从第二个字符起 rwxr 是说用户 root 具有读 写和运行权 接着的 xr 表示用户组 root 注意 在此 笔者用的是超级用户 roo

    2026年3月26日
    1
  • spss实现中心化处理、标准化处理和归一化处理

    spss实现中心化处理、标准化处理和归一化处理文章目录一 中心化 标准化 归一化简单描述二 中心化处理三 标准化处理四 归一化处理五 参考资料一 中心化 标准化 归一化简单描述意义 数据中心化和标准化在回归分析中是取消由于量纲不同 自身变异或者数值相差较大所引起的误差 原理数据标准化 是指数值减去均值 再除以标准差 数据中心化 是指变量减去它的均值 归一化 把数变为 0 1 之间的小数二 中心化处理 nbsp amp nbs

    2026年3月18日
    2
  • java Random.nextInt()方法

    java Random.nextInt()方法publicintnextInt(intn)该方法的作用是生成一个随机的int值,该值介于[0,n)的区间,也就是0到n之间的随机int值,包含0而不包含n。直接上代码:

    2022年7月4日
    30
  • 滨江涌起“养虾”热潮!光合组织OpenClaw龙虾局杭州场,安全与效率双在线

    滨江涌起“养虾”热潮!光合组织OpenClaw龙虾局杭州场,安全与效率双在线

    2026年3月14日
    2
  • yolo系列之yolo v3【深度解析】

    yolo系列之yolo v3【深度解析】yolo v3 是我最近一段时间主攻的算法 写下博客 以作分享交流 看过 yolov3 论文的应该都知道 这篇论文写得很随意 很多亮点都被作者都是草草描述 很多骚年入手 yolo 算法都是从 v3 才开始 这是不可能掌握 yolo 精髓的 因为 v3 很多东西是保留 v2 甚至 v1 的东西 而且 v3 的论文写得很随心 想深入了解 yolo v3 算法 必须先了解 v1 和 v2 以下是我关于 v1 和 v2 算法解析所写的文章 v1 算法

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号