2018 Multi-University Training Contest 4-Glad You Came(hdu 6356)
一、思路
线段树维护一个区间最小值,然后对于每次操作,做区间更新即可。要注意的是,在更新的时候,记得剪枝:如果当前更新的值$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)的更多相关文章
- 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 ...
- 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 ...
- 2018 Nowcoder Multi-University Training Contest 5
Practice Link A. gpa 题意: 有\(n\)门课程,每门课程的学分为\(s_i\),绩点为\(c_i\),要求最多删除\(k\)门课程,使得gpa最高. gpa计算方式如下: \[ ...
- 2018 Nowcoder Multi-University Training Contest 10
Practice Link J. Rikka with Nickname 题意: 给出\(n\)个字符串,要求依次合并两个串\(s, t\),满足将\(t\)合并到\(s\)中变成\(r\),使得\( ...
- 【HDU 2014 Multi-University Training Contest 1 1002】/【HDU 4862】Jump
多校训练就这么华丽丽的到了 ,于是乎各种华丽丽的被虐也開始了. 这是多校的1002; 最小费用最大流. 题目大意: 有n*m个方格,每一个方格都一个的十进制一位的数.你能够操作K次. 对于每一次操作, ...
- 【2014 Multi-University Training Contest 3 1002】/【HDU 4888】 Redraw Beautiful Drawings
不easy啊.最终能够补第二个题了.! 顺便说一句:模版写残了就不要怪出题人啊 ~ (这残废模版研究了好长时间才找出错) 题目大意: 有一个n*m的矩阵.每个格子里都将有一个数.给你每一行数字之和和每 ...
- 【2014 Multi-University Training Contest 2 1002】/【HDU 4873】 ZCC Loves Intersection
果然,或滥用零件,啥都不说了.我们欣慰地学习阅读.这两天残疾儿童是数学. 这是求所需的问题,不明确.贴上官方的解题报告. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi ...
- 2017 Multi-University Training Contest - Team 5——HDU6095&&HDU6090&&HDU
HDU6095——Rikka with Competition 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6095 题目意思:抱歉虽然是签到题,现场 ...
- 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 ...
- 2018 Multi-University Training Contest 2
题目链接:2018 Multi-University Training Contest 2 6318 Swaps and Inversions 题意:sum=x*逆序个数+交换次数*y,使sum最小 ...
随机推荐
- Codeforces Round #417 (Div. 2) D. Sagheer and Kindergarten(树中判祖先)
http://codeforces.com/contest/812/problem/D 题意: 现在有n个孩子,m个玩具,每次输入x y,表示x孩子想要y玩具,如果y玩具没人玩,那么x就可以去玩,如果 ...
- SQL Server2012创建约束图解
SQLServer中有五种约束:Primary Key约束.Foreign Key约束.Unique约束.Default约束和Check约束 1 . Primary Key 约束 在 ...
- Morgan logger
var logger = require("morgan"); res.render = function(view, options, fn){ options = option ...
- ElasticSearch安装和head插件安装
本文主要介绍elasticsearch5.0安装及head插件安装.确保系统已经安装好jdk1.8以上,操作系统CentOS6以上. 一.elasticsearch安装配置 1.官网下载源码包 下载不 ...
- Numpy np.array 相关常用操作
https://www.cnblogs.com/oftenlin/p/7856389.html
- linux系统时间获取方式
Linux 操作系统计算系统时间:主要函数:time localtime gmtime asctime ctime mktime difftime s ...
- EPANET头文件解读系列3——TOOLKIT.H
/******************************************************************** TOOLKIT.H - Prototypes for EPA ...
- Struts2基本使用(三)--数据交互
Struts2中的数据交互 在Struts2中我们不必再使用request.getParameter()这种方式来获取前台发送到服务器的参数. 我们可以在服务器端的Java类中直接声明一个和前台发送数 ...
- 网络编程I/O函数介绍
read和write #include <unistd.h> ssize_t read(int fd, void *buf, size_t count); ssize_t write(in ...
- New Concept English Two 32 88
$课文86 失控 940. As the man tried to swing the speedboat round, the steering wheel came away in his ha ...