博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 6521 Party
阅读量:6950 次
发布时间:2019-06-27

本文共 1481 字,大约阅读时间需要 4 分钟。

思路:

线段树玄学剪枝, 俗称吉司机线段树。

代码:

#pragma GCC optimize(2)#pragma GCC optimize(3)#pragma GCC optimize(4)#include
using namespace std;#define y1 y11#define fi first#define se second#define pi acos(-1.0)#define LL long long#define ls rt<<1, l, m#define rs rt<<1|1, m+1, r//#define mp make_pair#define pb push_back#define ULL unsigned LL#define pll pair
#define pli pair
#define pii pair
#define piii pair
#define pdi pair
#define pdd pair
#define mem(a, b) memset(a, b, sizeof(a))#define debug(x) cerr << #x << " = " << x << "\n";#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);//headconst int N = 5e5 + 5;LL sum[N<<2];int mn[N<<2];int n, m, l, r;void push_up(int rt) { mn[rt] = min(mn[rt<<1], mn[rt<<1|1]); sum[rt] = sum[rt<<1] + sum[rt<<1|1];}void build(int rt, int l, int r) { if(l == r) { sum[rt] = 0; mn[rt] = l; return ; } int m = l+r >> 1; build(ls); build(rs); push_up(rt);}LL query(int L, int R, int rt, int l, int r) { LL ans = 0; if(mn[rt] >= R) return 0; if(l == r) { ans = R-mn[rt]; mn[rt] = R; return ans; } int m = l+r >> 1; if(L <= m) ans += query(L, R, ls); if(R > m) ans += query(L, R, rs); push_up(rt); return ans;}int main() { while(~scanf("%d %d", &n, &m)) { build(1, 1, n); for (int i = 1; i <= m; ++i) { scanf("%d %d", &l, &r); printf("%lld\n", query(l, r, 1, 1, n)); } } return 0;}

 

转载于:https://www.cnblogs.com/widsom/p/10768770.html

你可能感兴趣的文章
mac关闭和开启启动声
查看>>
浅谈WebService开发(一)
查看>>
学习Zookeeper之第2章Zookeeper安装
查看>>
java开始到熟悉100-102
查看>>
(译)我为什么用Go语言来做区块链——Syed Jafar Naqvi——Co-Founder/CEO at Karachain...
查看>>
随机生成一个不重复的身份码,包含数字和字母
查看>>
王彪-20162321-实验二 树
查看>>
HDU 1754 线段树裸题
查看>>
异常处理
查看>>
Mysql事件学习
查看>>
整合思路、步骤
查看>>
本地==〉Github(push)
查看>>
Ural 1004 FLOYD最小环问题
查看>>
html5——canvas画布
查看>>
数据标准化处理,data.mean和data.std
查看>>
Ajax(简介、基础操作、计算器,登录验证)
查看>>
用ElasticSearch存储日志
查看>>
Linux定时备份mysql数据库
查看>>
[中英双语] 数学缩写列表 (List of mathematical abbreviations)
查看>>
[leetcode-150-Evaluate Reverse Polish Notation]
查看>>