https://vjudge.net/contest/446582#problem/B

这道题是一道不错的线段树练代码能力的题。

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+5;
char s[N];
int a[N];
struct segmentree {
int l,r,cnt[27],lazy[27];
}T[N];
void Push_up(int x) {
for(int i=0;i<26;i++)T[x].cnt[i]=T[x*2].cnt[i]+T[x*2+1].cnt[i];
}
void Build_tree(int x,int l,int r) {
T[x].l=l,T[x].r=r;
for(int i=0;i<26;i++) T[x].cnt[i]=0,T[x].lazy[i]=-1;
if(l==r) {T[x].cnt[a[l]]++;return;}
int mid=(T[x].l+T[x].r)>>1;
Build_tree(x*2,l,mid),Build_tree(x*2+1,mid+1,r);
Push_up(x);
}
void Push_down(int x) {
for(int i=0;i<26;i++) {
if(T[x].lazy[i]==0) T[x*2].cnt[i]=T[x*2+1].cnt[i]=T[x*2].lazy[i]=T[x*2+1].lazy[i]=0;
if(T[x].lazy[i]==1) {
T[x*2].cnt[i]=T[x*2].r-T[x*2].l+1,T[x*2].lazy[i]=1;
T[x*2+1].cnt[i]=T[x*2+1].r-T[x*2+1].l+1,T[x*2+1].lazy[i]=1;
}
}
for(int i=0;i<26;i++) T[x].lazy[i]=-1;
}
void Update(int x,int l,int r,int p) { //[l,r]->p
if(l<=T[x].l&&T[x].r<=r) {
for(int i=0;i<26;i++)T[x].cnt[i]=T[x].lazy[i]=0;
T[x].cnt[p]=T[x].r-T[x].l+1,T[x].lazy[p]=1;
return;
}
Push_down(x);
int mid=(T[x].l+T[x].r)>>1;
if(l<=mid)Update(x*2,l,r,p);
if(r>mid)Update(x*2+1,l,r,p);
Push_up(x);
}
int get_cnt(int x,int l,int r,int p) {
if(l<=T[x].l&&T[x].r<=r) return T[x].cnt[p];
Push_down(x);
int sum=0,mid=(T[x].l+T[x].r)>>1;
if(l<=mid)sum+=get_cnt(x*2,l,r,p);
if(r>mid)sum+=get_cnt(x*2+1,l,r,p);
return sum;
}
int Cnt[27];
int main() {
int n,q;
scanf("%d%d",&n,&q);
scanf("%s",s);
for(int i=1;i<=n;i++)a[i]=s[i-1]-'a';
Build_tree(1,1,n);
while(q--) {
int x,y,k;
scanf("%d%d%d",&x,&y,&k);
if(!k) {
for(int i=0;i<26;i++) Cnt[i]=get_cnt(1,x,y,i);
int L=x,R;
for(int i=25;i>=0;i--) {
if(!Cnt[i])continue;
R=L+Cnt[i]-1;
Update(1,L,R,i);
L=R+1;
}
}
else {
for(int i=0;i<26;i++) Cnt[i]=get_cnt(1,x,y,i);
int L=x,R;
for(int i=0;i<26;i++) {
if(!Cnt[i])continue;
R=L+Cnt[i]-1;
Update(1,L,R,i);
L=R+1;
}
}
}
for(int i=1;i<=n;i++) {
for(int j=0;j<26;j++) {
if(get_cnt(1,i,i,j)) {
printf("%c",(char)('a'+j));break;
}
}
}
return 0;
}

B - A Simple Task的更多相关文章

  1. 计数排序 + 线段树优化 --- Codeforces 558E : A Simple Task

    E. A Simple Task Problem's Link: http://codeforces.com/problemset/problem/558/E Mean: 给定一个字符串,有q次操作, ...

  2. HDU-1339 A Simple Task

    http://acm.hdu.edu.cn/showproblem.php?pid=1339 正常做法超时,要有点小技巧存在. A Simple Task Time Limit: 2000/1000 ...

  3. A Simple Task

    A Simple Task Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

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

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

  5. Codeforces Round #312 (Div. 2) E. A Simple Task 线段树

    E. A Simple Task 题目连接: http://www.codeforces.com/contest/558/problem/E Description This task is very ...

  6. Codeforces Round #312 (Div. 2) E. A Simple Task 线段树+计数排序

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

  7. 【题解】 CF11D A Simple Task

    [题解] CF11D A Simple Task 传送门 \(n \le 20\) 考虑状态压缩\(dp\). 考虑状态,\(dp(i,j,O)\)表示从\(i\)到\(j\)经过点集\(O\)的路径 ...

  8. Codeforces 558E A Simple Task(权值线段树)

    题目链接  A Simple Task 题意  给出一个小写字母序列和若干操作.每个操作为对给定区间进行升序排序或降序排序. 考虑权值线段树. 建立26棵权值线段树.每次操作的时候先把26棵线段树上的 ...

  9. A Simple Task CodeForces - 11D

    A Simple Task CodeForces - 11D 题意:输出一个无向图的简单环数量.简单环指无重复边的环.保证图无重边自环. ans[i][j]表示"包含i中的点,以i中第一个点 ...

  10. Codeforces Round #312 (Div. 2) E. A Simple Task 线段树 延时标记

    E. A Simple Task time limit per test5 seconds memory limit per test512 megabytes inputstandard input ...

随机推荐

  1. ios audio不能够正常播放

    ios中audio不能直接通过audio.play()播放,需要用户在click事件或者touch事件中执行audio.play()才能播放. ajax回调中audio.play()音乐不能正常播放. ...

  2. js判断json数据是否存在某字段的方法

    方式一 !("key" in obj) if("name" in json){//json就是数组,name是你要找的值 console.log("有 ...

  3. WIN DLL劫持提权

    WIN DLL劫持提权 原理: Windows程序启动的时候需要DLL.如果这些DLL 不存在,则可以通过在应用程序要查找的位置放置恶意DLL来提权.通常,Windows应用程序有其预定义好的搜索DL ...

  4. victoriaMetrics之byteBuffer

    victoriaMetrics之byteBuffer VictoriaMetrics经常会处理数目庞大的指标,在处理的过程中会涉及指标的拷贝,如果在指标拷贝时都进行内存申请的话,其内存消耗和性能损耗都 ...

  5. QGIS 安装

    QGIS 安装 官网 https://www.qgis.org/ 下载地址 https://www.qgis.org/en/site/forusers/download.html 参考文档 https ...

  6. DjangoRestFramework框架三种分页功能的实现 - 在DjangoStarter项目模板中封装

    前言 继续Django后端开发系列文章.刚好遇到一个分页的需求,就记录一下. Django作为一个"全家桶"型的框架,本身啥都有,分页组件也是有的,但默认的分页组件没有对API开发 ...

  7. 内存之旅——如何提升CMA利用率?

    ​(以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点)​ 宋远征 李佳伟 OpenAtom OpenHarmony(以下简称"OpenHarmony") ...

  8. gin框架使用【4.请求参数】

    GET url: http://127.0.0.1:8080/users?id=1&name=卷毛狒狒 package mainimport ( "github.com/gin-go ...

  9. android软件简约记账app开发day04-记账页面条目的代码书写

    android软件简约记账app开发day04-记账页面条目的代码书写 在前三天我们完成了基本的界面展示,从今天开始,我们进入到后台逻辑代码的编写中,今天开发记账条目的代码 我们在主页面点击记一笔图标 ...

  10. v74.01 鸿蒙内核源码分析(编码方式篇) | 机器指令是如何编码的 | 百篇博客分析OpenHarmony源码

    本篇关键词:指令格式.条件域.类型域.操作域.数据指令.访存指令.跳转指令.SVC(软件中断) 内核汇编相关篇为: v74.01 鸿蒙内核源码分析(编码方式) | 机器指令是如何编码的 v75.03 ...