题目链接  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头脑风暴4

    IT是全国平均薪资最高的行业,2017年全国最高,人均13点4万每年. 但技术固然好,创业拼的还是世界观下的创意. 蘑菇街,并夕夕,TikTok,头条,哪个不是创意用IT技术的现实化?? 未来,大平台 ...

  2. Python全栈之jQuery笔记

    jQuery runnoob网址: http://www.runoob.com/jquery/jquery-tutorial.html jQuery API手册: http://www.runoob. ...

  3. CRC点滴

    研究了一个晚上,大致看懂了crc校验的方法.这里记录一下,因为can总线中需要用到crc校验的. 举例说明CRC校验码的求法:(此例子摘自百度百科:CRC校验码) 信息字段代码为: 1011001:对 ...

  4. HUD:4405-Aeroplane chess(期望飞行棋)

    Aeroplane chess Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Pro ...

  5. MIP启发式算法:local branching

    *本文主要是记录并分享最近学习到的知识,算不上原创 *参考文献见链接 本文主要是讲述local branching算法,主要以M. Fischetti的论文 “Local braching”和Pier ...

  6. 关于.ascx

    .ascx用户控件  参考系列教程User controls in asp.net - Part 104 用户控件包含了html.代码和其他Web或者用户控件的组合,并在Web服务器上以自己的文件格式 ...

  7. selenium2断言类Assert的使用

    测试中断言的重要性 一.断言的作用: 1.断言也就是检查点,重在判断我们通过页面得出来的值与期望值是否相等,如果相等,则代表断言成功,程序会继续往下执行,如果不相等,则代表断言失败,程序就会在断言失败 ...

  8. 《Scrum实战》第1课【知易行难】全团课后任务汇总

          1组 孟帅(班长)   kecyru 2017-7-5 http://kecyru.blog.163.com/blog/static/27416617320176411513013 htt ...

  9. body标签相关

    03-body标签中相关标签   今日主要内容: 列表标签 <ul>.<ol>.<dl> 表格标签 <table> 表单标签 <fom> 一 ...

  10. Selenium WebDriver-actionchain模拟鼠标右键操作

    #encoding=utf-8 import unittest import time from selenium import webdriver from selenium.webdriver i ...