题目链接  A Simple Task

题意  给出一个小写字母序列和若干操作。每个操作为对给定区间进行升序排序或降序排序。

考虑权值线段树。

建立26棵权值线段树。每次操作的时候先把26棵线段树上的所有在该区间内的信息清空。

然后再通过类似计数排序的方式从左往右(或从右往左)依次塞进去。

#include <bits/stdc++.h>

using namespace std;

#define rep(i, a, b)	for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i)
#define ls i << 1
#define rs i << 1 | 1
#define lson ls, L, mid
#define rson rs, mid + 1, R typedef long long LL; const int N = 1e5 + 10; struct node{
int sum[2];
int len;
} s[27][N * 3]; int n, q;
int a[N];
char st[N];
int dc[27][N * 3];
int f[27]; inline node update(const node &x, const node &y){
node ret;
ret.len = x.len + y.len;
rep(i, 0, 1) ret.sum[i] = x.sum[i] + y.sum[i];
return ret;
} void build(int cnt, int i, int L, int R){
if (L == R){
int z = a[L] == cnt;
s[cnt][i].len = 1;
s[cnt][i].sum[z] = 1;
s[cnt][i].sum[z ^ 1] = 0;
dc[cnt][i] = -1;
return;
} int mid = (L + R) >> 1;
build(cnt, lson);
build(cnt, rson);
s[cnt][i] = update(s[cnt][ls], s[cnt][rs]);
dc[cnt][i] = -1;
} inline void paintcover(int cnt, int i, int z){
dc[cnt][i] = z;
s[cnt][i].sum[z] = s[cnt][i].len;
s[cnt][i].sum[z ^ 1] = 0;
} inline void pushdown(int cnt, int i){
if (~dc[cnt][i]){
paintcover(cnt, ls, dc[cnt][i]);
paintcover(cnt, rs, dc[cnt][i]);
dc[cnt][i] = -1;
}
} void cover(int cnt, int i, int L, int R, int l, int r, int z){
if (l <= L && R <= r){
paintcover(cnt, i, z);
return;
} pushdown(cnt, i);
int mid = (L + R) >> 1;
if (l <= mid) cover(cnt, lson, l, r, z);
if (r > mid) cover(cnt, rson, l, r, z);
s[cnt][i] = update(s[cnt][ls], s[cnt][rs]);
} int query(int cnt, int i, int L, int R, int l, int r){
int ret = 0;
if (l <= L && R <= r) return s[cnt][i].sum[1];
int mid = (L + R) >> 1;
pushdown(cnt, i);
if (l <= mid) ret += query(cnt, lson, l, r);
if (r > mid) ret += query(cnt, rson, l, r);
return ret;
} int main(){ scanf("%d%d", &n, &q);
scanf("%s", st + 1);
rep(i, 1, n) a[i] = (int)st[i] - 96;
rep(i, 1, 26) build(i, 1, 1, n); while (q--){
int x, y, z;
scanf("%d%d%d", &x, &y, &z);
rep(i, 1, 26) f[i] = query(i, 1, 1, n, x, y);
rep(i, 1, 26) cover(i, 1, 1, n, x, y, 0);
if (z){
int pos = x;
rep(i, 1, 26) if (f[i]){
cover(i, 1, 1, n, pos, pos + f[i] - 1, 1);
pos += f[i];
}
} else{
int pos = x;
dec(i, 26, 1) if (f[i]){
cover(i, 1, 1, n, pos, pos + f[i] - 1, 1);
pos += f[i];
}
}
} rep(i, 1, n){
rep(j, 1, 26) if (query(j, 1, 1, n, i, i)){
putchar(j + 96);
break;
}
} putchar(10);
return 0;
}

  

Codeforces 558E A Simple Task(权值线段树)的更多相关文章

  1. Codeforces 558E A Simple Task (计数排序&&线段树优化)

    题目链接:http://codeforces.com/contest/558/problem/E E. A Simple Task time limit per test5 seconds memor ...

  2. Codeforces 666E Forensic Examination SAM+权值线段树

    第一次做这种$SAM$带权值线段树合并的题 然而$zjq$神犇看完题一顿狂码就做出来了 $Orz$ 首先把所有串当成一个串建$SAM$ 我们对$SAM$上每个点 建一棵权值线段树 每个叶子节点表示一个 ...

  3. D. Restore Permutation(权值线段树)

    D. Restore Permutation time limit per test 2 seconds memory limit per test 256 megabytes input stand ...

  4. 线段树(单标记+离散化+扫描线+双标记)+zkw线段树+权值线段树+主席树及一些例题

    “队列进出图上的方向 线段树区间修改求出总量 可持久留下的迹象 我们 俯身欣赏” ----<膜你抄>     线段树很早就会写了,但一直没有总结,所以偶尔重写又会懵逼,所以还是要总结一下. ...

  5. 【树状数组套权值线段树】bzoj1901 Zju2112 Dynamic Rankings

    谁再管这玩意叫树状数组套主席树我跟谁急 明明就是树状数组的每个结点维护一棵动态开结点的权值线段树而已 好吧,其实只有一个指针,指向该结点的权值线段树的当前结点 每次查询之前,要让指针指向根结点 不同结 ...

  6. 【BZOJ-2892&1171】强袭作战&大sz的游戏 权值线段树+单调队列+标记永久化+DP

    2892: 强袭作战 Time Limit: 50 Sec  Memory Limit: 512 MBSubmit: 45  Solved: 30[Submit][Status][Discuss] D ...

  7. BZOJ 3110 ZJOI 2013 K大数查询 树套树(权值线段树套区间线段树)

    题目大意:有一些位置.这些位置上能够放若干个数字. 如今有两种操作. 1.在区间l到r上加入一个数字x 2.求出l到r上的第k大的数字是什么 思路:这样的题一看就是树套树,关键是怎么套,怎么写.(话说 ...

  8. 动态求区间K大值(权值线段树)

    我们知道我们可以通过主席树来维护静态区间第K大值.我们又知道主席树满足可加性,所以我们可以用树状数组来维护主席树,树状数组的每一个节点都可以开一颗主席树,然后一起做. 我们注意到树状数组的每一棵树都和 ...

  9. 【BZOJ3685】【zkw权值线段树】普通van Emde Boas树

    原题传送门 因为马上要开始搞树套树了,所以学了一波权值线段树...毕竟是会点zkw线段树的,所以zkw线段树大法好! 解题思路: 介绍一下权值线段树吧,其实感觉就是线段树的本义,就是你用线段树维护了数 ...

随机推荐

  1. Python头脑风暴2

    今天想到了一个致富新途径:假如我在X东上班,我写个X宝爬虫,专门爬在X宝买奢侈品的土豪,然后我自己注册个X宝号,用脚本一个个加他们然后给他们发信息说我X东这还有比你更便宜更好的...不知道行不行啊(狗 ...

  2. 使用python3调用MyQR库生成动态二维码(附源代码)

    可生成普通二维码.带图片的艺术二维码(黑白与彩色).动态二维码(黑白与彩色). GitHub:https://github.com/sylnsfar/qrcode 中文版:https://github ...

  3. LeetCode(238) Product of Array Except Self

    题目 Given an array of n integers where n > 1, nums, return an array output such that output[i] is ...

  4. 浅谈内核的Makefile、Kconfig和.config文件

    Linux内核源码文件繁多,搞不清Makefile.Kconfig..config间的关系,不了解内核编译体系,编译修改内核有问题无从下手,自己写的驱动不知道怎么编进内核,不知道怎么配置内核,这些问题 ...

  5. Linux学习-仅执行一次的工作排程

    atd 的启动与 at 运作的方式 要使用单一工作排程时,我们的 Linux 系统上面必须要有负责这个排程的服务,那就是 atd 这个玩 意儿. 不过并非所有的 Linux distributions ...

  6. jmeter中重要组件及其执行顺序

    jmeter中重要组件有:Sampler,计时器,前置处理器和后置处理器,断言,Controller,Listener和配置原件. 同类组件之间是从上到下的顺序执行,不同组件之间是按照以下的顺序执行的 ...

  7. 编程哲学之 C# 篇:007——如何创造万物

    上帝拥有创建万物的能力,本文介绍创造万物的道,让你也拥有上帝般创造万物的能力! 道 中国哲学家,道家学派创始人--老子,在<道德经>写到: 道生一,一生二,二生三,三生万物 那么,是什么 ...

  8. day18-socket 编程

    1.Socket是网络上的使用的交互信息得方法,也叫套接字 用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. 通讯原理 Soc ...

  9. luogu2754 星际转移问题

    源向地球连 月球向汇连 每一天往下一天连 飞船上一天与这一天连 枚举答案 #include <iostream> #include <cstring> #include < ...

  10. Selenium WebDriver-操作页面下拉列表

    #encoding=utf-8 import unittest import time import chardet from selenium import webdriver class Visi ...