一、思路

线段树维护一个区间最小值,然后对于每次操作,做区间更新即可。要注意的是,在更新的时候,记得剪枝:如果当前更新的值$v \le minv$(minv为当前线段树节点所管辖区间的最小值),直接返回。否则,TLE。运行时间1500+ms,比标程2800+ms快将近两倍。

二、代码

#include<bits/stdc++.h>
using namespace std;
#define min(x, y) (x < y ? x : y)
#define max(x, y) (x > y ? x : y)
#define MAXN 100100

unsigned X, Y, Z;
struct node {
    int mv, lazy;
} data[MAXN * ];
int n, m;

inline void down(int rt) {
    if(data[rt].lazy) {
        , rch = rt <<  | ;
        if(data[lch].lazy < data[rt].lazy)data[lch].lazy = data[rt].lazy;
        if(data[lch].mv < data[rt].lazy)data[lch].mv = data[rt].lazy;
        if(data[rch].lazy < data[rt].lazy)data[rch].lazy = data[rt].lazy;
        if(data[rch].mv < data[rt].lazy)data[rch].mv = data[rt].lazy;
        data[rt].lazy = ;
    }
}

inline , , int r = n) {
    if(l > ur || r < ul)return;
    if(v <= data[rt].mv)return;
    if(l >= ul && r <= ur) {
        if(data[rt].mv < v)data[rt].mv = v, data[rt].lazy = v;
        return;
    }
    down(rt);
    ;
    update(ul, ur, v, rt << , l, mid);
    update(ul, ur, v, rt <<  | , mid + , r);
    data[rt].mv = min(data[rt << ].mv, data[rt <<  | ].mv);
}

inline , , int r = n) {
    if(l == r)return data[rt].mv;
    down(rt);
    ;
    , l, mid);
     | , mid + , r);
}

inline unsigned rng61() {
    X ^= X << ;
    X ^= X >> ;
    X ^= X << ;
    X ^= X >> ;
    unsigned W = X ^ Y ^ Z;
    X = Y; Y = Z; Z = W;
    return Z;
}

int main() {
//    freopen("1007.in", "r", stdin);
//    freopen("1007.out", "w", stdout);
     << ) - ;
    scanf("%d", &T);
    ; ca < T; ++ca) {
        scanf("%d%d%u%u%u", &n, &m, &X, &Y, &Z);
        memset(data, , ]) * ((n << ) + ));
        ; jj < m; ++jj) {
            unsigned f1 = rng61(), f2 = rng61();
            if(f1 >= n)f1 %= n;
            if(f2 >= n)f2 %= n;
            , ur = f2 + , v = rng61() & mod;
            if(ul > ur)swap(ul, ur);
            update(ul, ur, v);
        }
        ;
        ; i <= n; ++i)ans ^= 1LL * i * query(i);
        printf("%lld\n", ans);
    }
    ;
}

2018 Multi-University Training Contest 4-Glad You Came(hdu 6356)的更多相关文章

  1. 2018 Nowcoder Multi-University Training Contest 2

    目录 Contest Info Solutions A. run D. monrey G. transform H. travel I. car J. farm Contest Info Practi ...

  2. 2018 Nowcoder Multi-University Training Contest 1

    Practice Link J. Different Integers 题意: 给出\(n\)个数,每次询问\((l_i, r_i)\),表示\(a_1, \cdots, a_i, a_j, \cdo ...

  3. 2018 Nowcoder Multi-University Training Contest 5

    Practice Link A. gpa 题意: 有\(n\)门课程,每门课程的学分为\(s_i\),绩点为\(c_i\),要求最多删除\(k\)门课程,使得gpa最高. gpa计算方式如下: \[ ...

  4. 2018 Nowcoder Multi-University Training Contest 10

    Practice Link J. Rikka with Nickname 题意: 给出\(n\)个字符串,要求依次合并两个串\(s, t\),满足将\(t\)合并到\(s\)中变成\(r\),使得\( ...

  5. 【HDU 2014 Multi-University Training Contest 1 1002】/【HDU 4862】Jump

    多校训练就这么华丽丽的到了 ,于是乎各种华丽丽的被虐也開始了. 这是多校的1002; 最小费用最大流. 题目大意: 有n*m个方格,每一个方格都一个的十进制一位的数.你能够操作K次. 对于每一次操作, ...

  6. 【2014 Multi-University Training Contest 3 1002】/【HDU 4888】 Redraw Beautiful Drawings

    不easy啊.最终能够补第二个题了.! 顺便说一句:模版写残了就不要怪出题人啊 ~ (这残废模版研究了好长时间才找出错) 题目大意: 有一个n*m的矩阵.每个格子里都将有一个数.给你每一行数字之和和每 ...

  7. 【2014 Multi-University Training Contest 2 1002】/【HDU 4873】 ZCC Loves Intersection

    果然,或滥用零件,啥都不说了.我们欣慰地学习阅读.这两天残疾儿童是数学. 这是求所需的问题,不明确.贴上官方的解题报告. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi ...

  8. 2017 Multi-University Training Contest - Team 5——HDU6095&&HDU6090&&HDU

    HDU6095——Rikka with Competition 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6095 题目意思:抱歉虽然是签到题,现场 ...

  9. HDU 2018 Multi-University Training Contest 3 Problem A. Ascending Rating 【单调队列优化】

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=6319 Problem A. Ascending Rating Time Limit: 10000/500 ...

  10. 2018 Multi-University Training Contest 2

    题目链接:2018 Multi-University Training Contest 2 6318 Swaps and Inversions 题意:sum=x*逆序个数+交换次数*y,使sum最小 ...

随机推荐

  1. UVa 11270 铺放骨牌(轮廓线DP)

    https://vjudge.net/problem/UVA-11270 题意: 用1×2骨牌覆盖n×m棋牌,有多少种方法? 思路: 这道题目是典型的轮廓线DP题. 所谓轮廓线DP,就是以整行整列为状 ...

  2. Codeforces Round #394 (Div. 2) C.Dasha and Password(暴力)

    http://codeforces.com/contest/761/problem/C 题意:给出n个串,每个串的初始光标都位于0(列)处,怎样移动光标能够在凑出密码(每个串的光标位置表示一个密码的字 ...

  3. css 基础 - 3

    css 基础 - 3 20161128   一. 元素的距离计算 1,两个水平方向的容器s1,s2之间的距离计算为s: s = s1的margin-right + s2的margin-left(+默认 ...

  4. 安装pip最简单的方法

    http://blog.csdn.net/lyj_viviani/article/details/70568434

  5. ADSL拨号上网或者光纤上网设置概要(原创)

    不管是在梧州设置光纤还是在太平设置ADSL拨号上网每次设置上网一体机的时候都是遇到各种麻烦...这次又是弄了N久,每次问题各不一样.总结一下操作过程,方便以后又遇问题回头查询自个微博.一.设置电话线的 ...

  6. Pave the Parallelepiped CodeForces - 1007B (计数)

    大意: 给定A,B,C, 求有多少个三元组$(a,b,c)$, 满足$a \le b \le c$, 且以若干个$(a,b,c)$为三边的长方体能填满边长(A,B,C)的长方体. 暴力枚举出$A,B, ...

  7. 51nod-1455-dp/缩小范围

    1455 宝石猎人  题目来源: CodeForces 基准时间限制:2 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 苏塞克岛是一个有着30001个小岛的群岛,这 ...

  8. Hadoop生态系统介绍

    Hadoop生态系统Hadoop1.x 的各项目介绍1. HDFS2. MapReduce3. Hive4. Pig5. Mahout6. ZooKeeper7. HBase8. Sqoop9. Fl ...

  9. .properties文件常量定义

    application.properties文件,位于resources目录下.一般定义一些不会改变的数据如数据库相关配置,文件路径,项目地址. 如何在项目代码中获取该文件中的配置信息: 1,在app ...

  10. 如何在IDEA启动多个Spring Boot工程实例

    在我讲解的案例中,经常一个工程启动多个实例,分别占用不同的端口,有很多读者百思不得其解,在博客上留言,给我发邮件,加我微信询问.所以有必要在博客上记录下,方便读者. step 1 在IDEA上点击Ap ...