题目大意

给你一个环形数列,完成环形数列上区间加法和区间求最小值。

分析

算是一道比较水的线段树模板题。
如果l>r的话,那么修改l,n和1,r区间。
不然的话那么就修改l,r区间。
其他的基础操作可以看我的随笔:【传送门】
还要注意开long long

ac代码

#include <bits/stdc++.h>
#define inf 0x3f3f3f3f
#define N 200005
#define ll long long
#define linf 9223372036854775807
using namespace std;
ll a[N];
bool bo;
template <typename T>
inline void read(T &x) {
    x = 0; T fl = 1;
    bo = 0;
    char ch = 0;
    while (ch < '0' || ch > '9') {
        if (ch == '-') fl = -1;
        ch = getchar();
    }
    while (ch >= '0' && ch <= '9') {
        x = (x << 1) + (x << 3) + (ch ^ 48);
        ch = getchar();
    }
    if (ch == ' ') bo = 1;
    x *= fl;
}
struct segment_tree {
    #define lc (nod << 1)
    #define rc (nod << 1 | 1)
    #define mid ((l + r) >> 1)
    struct node {
        ll mn, tag;
        int l, r;
        node() {
            mn = l = r = tag;
        }
    }tr[N << 2];
    void pushup(int nod) {
        tr[nod].mn = min(tr[lc].mn, tr[rc].mn);
    }
    void pushdown(int nod) {
        if (tr[nod].tag == 0 || tr[nod].l == tr[nod].r) return;
        ll tmp = tr[nod].tag;
        tr[nod].tag = 0;
        tr[lc].mn += tmp;
        tr[rc].mn += tmp;
        tr[lc].tag += tmp;
        tr[rc].tag += tmp;
    }
    void build(int l, int r, int nod, ll *a) {
        tr[nod].l = l, tr[nod].r = r;
        if (l == r) {
            tr[nod].mn = a[l];
            return;
        }
        build(l, mid, lc, a);
        build(mid + 1, r, rc, a);
        pushup(nod);
    }
    void update_sec(int ql, int qr, int nod, ll val) {
        int l = tr[nod].l, r = tr[nod].r;
        pushdown(nod);
        if (ql <= l && r <= qr) {
            tr[nod].mn += val;
            tr[nod].tag += val;
            return;
        }
        if (ql <= mid) update_sec(ql, qr, lc, val);
        if (qr > mid) update_sec(ql, qr, rc, val);
        pushup(nod);
    }
    ll query_sec_min(int ql, int qr, int nod) {
        int l = tr[nod].l, r = tr[nod].r;
        pushdown(nod);
        if (ql <= l && r <= qr) return tr[nod].mn;
        ll res = linf;
        if (ql <= mid) res = min(res, query_sec_min(ql, qr, lc));
        if (qr > mid) res = min(res, query_sec_min(ql, qr, rc));
        return res;
    }
}tr;
int n, m;
int main() {
    read(n);
    for (int i = 1; i <= n; i ++) read(a[i]);
    tr.build(1, n, 1, a);
    read(m);
    while (m --) {
        int l, r;
        read(l); read(r);
        l ++; r ++;
        if (!bo) {
            ll res = linf;
            if (l > r) {
                res = min(res, tr.query_sec_min(l, n, 1));
                res = min(res, tr.query_sec_min(1, r, 1));
            }
            else res = min(res, tr.query_sec_min(l, r, 1));
            printf("%lld\n", res);
        }
        else {
            ll x;
            cin>> x;
            if (l > r) {
                tr.update_sec(l, n, 1, x);
                tr.update_sec(1, r, 1, x);
            }
            else tr.update_sec(l, r, 1, x);
        }
    }
    return 0;
}

[CF52C]Circular RMQ【线段树】的更多相关文章

  1. NBU 2475 Survivors(RMQ线段树)

    NBU 2475Survivors 题目链接:http://acm.nbu.edu.cn/v1.0/Problems/Problem.php?pid=2475 题意:给定n个人,每个人有strengt ...

  2. UESTC 764 失落的圣诞节 --RMQ/线段树

    题意:n种物品,每种物品对不同的人都有不同的价值,有三个人选,第一个为普通学生,第二个是集,第三个是祈,集和祈可以选一样的,并且还会获得加分,集和祈选的普通学生都不能选,问三个人怎样选才能使总分最高. ...

  3. [RMQ] [线段树] POJ 3368 Frequent Values

    一句话,多次查询区间的众数的次数 注意多组数据!!!! RMQ方法: 预处理 i 及其之前相同的数的个数 再倒着预处理出 i 到不是与 a[i] 相等的位置之前的一个位置, 查询时分成相同的一段和不同 ...

  4. VJ16216/RMQ/线段树单点更新

    题目链接 /* 单点更新,用RMQ维护最大值,add对c[i]修改,或加,或减. 求[l,r]的和,用sum(r)-sum(l-1).即可. */ #include<cmath> #inc ...

  5. 51Nod.1766.树上最远点对(树的直径 RMQ 线段树/ST表)

    题目链接 \(Description\) 给定一棵树.每次询问给定\(a\sim b,c\sim d\)两个下标区间,从这两个区间中各取一个点,使得这两个点距离最远.输出最远距离. \(n,q\leq ...

  6. lca 欧拉序+rmq(st) 欧拉序+rmq(线段树) 离线dfs 倍增

    https://www.luogu.org/problemnew/show/P3379 1.欧拉序+rmq(st) /* 在这里,对于一个数,选择最左边的 选择任意一个都可以,[left_index, ...

  7. ACM学习历程—HDU5696 区间的价值(分治 && RMQ && 线段树 && 动态规划)

    http://acm.hdu.edu.cn/showproblem.php?pid=5696 这是这次百度之星初赛2B的第一题,但是由于正好打省赛,于是便错过了.加上2A的时候差了一题,当时有思路,但 ...

  8. poj2763(lca / RMQ + 线段树)

    题目链接: http://poj.org/problem?id=2763 题意: 第一行输入 n, q, s 分别为树的顶点个数, 询问/修改个数, 初始位置. 接下来 n - 1 行形如 x, y, ...

  9. CSU1553 Good subsequence —— 二分 + RMQ/线段树

    题目链接: http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1553 Description Give you a sequence of n n ...

随机推荐

  1. Elasticsearch IK+pinyin

    如何在Elasticsearch中安装中文分词器(IK+pinyin)   如果直接使用Elasticsearch的朋友在处理中文内容的搜索时,肯定会遇到很尴尬的问题——中文词语被分成了一个一个的汉字 ...

  2. CentOS 6.5 手动rpm包安装gcc、g++

    摘自:https://blog.csdn.net/lichen_net/article/details/70211204 mount CentOS的安装光盘,然后先后安装 rpm -ivh ppl-0 ...

  3. Notepad++远程连接Linux系统

    首先在官网下载 https://notepad-plus-plus.org/news/notepad-7.6.4-released.html 在命令行数输入ifconfig 查看自己的Linux的ip ...

  4. asp.net core前后端分离

    陆陆续续的看了两个礼拜的前端知识,把vue+vue-router+axios的知识撸了一遍,本来想加个element-ui来实现一下前后端分离,实施的时候却遇到了很多的坑.我本身不在一个软件开发公司上 ...

  5. html 引入页面公共部分(header、footer)

    html引入页面的公共部分,比如导航栏啊,页头页脚之类的. 1.将需要引入的公共html部分转换为js文件,这里推荐一个转换工具地址 http://tool.chinaz.com/Tools/Html ...

  6. fastclick的介绍和使用

    移动端点击延迟事件 1. 移动端浏览器在派发点击事件的时候,通常会出现300ms左右的延迟 2. 原因: 移动端的双击会缩放导致click判断延迟 解决方式 1. 禁用缩放 `<meta nam ...

  7. 关于IWMS后台登录问题总结

    一.登录后台,点击登录无反应: 1.是因为网站文件夹没有权限,需要右击文件夹,将只读勾选去掉 2.在安全中加入Everyone对象. 二.登录后台后,左边显示不全,是因为会员权限不够,需要给权限.

  8. QTP 自动化测试--点滴 获取datatable数值/dafault文件位置

    0 设置default.xls文件位置 右键项目-settings-resources-datatable-选择 数据表的位置如图 心得:同一个项目-分成多个测试项目-这些测试项目可以共用同一张数据表 ...

  9. 循环神经网络RNN及LSTM

    一.循环神经网络RNN RNN综述 https://juejin.im/entry/5b97e36cf265da0aa81be239 RNN中为什么要采用tanh而不是ReLu作为激活函数?  htt ...

  10. CSS3之box-sizing属性

    box-sizing本身有三个属性:content-box(默认).border-box和padding-box. content-box:border与padding均不算入width中: bord ...