B - A Simple Task
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的更多相关文章
- 计数排序 + 线段树优化 --- Codeforces 558E : A Simple Task
E. A Simple Task Problem's Link: http://codeforces.com/problemset/problem/558/E Mean: 给定一个字符串,有q次操作, ...
- HDU-1339 A Simple Task
http://acm.hdu.edu.cn/showproblem.php?pid=1339 正常做法超时,要有点小技巧存在. A Simple Task Time Limit: 2000/1000 ...
- A Simple Task
A Simple Task Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- Codeforces 558E A Simple Task (计数排序&&线段树优化)
题目链接:http://codeforces.com/contest/558/problem/E E. A Simple Task time limit per test5 seconds memor ...
- 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 ...
- 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 ...
- 【题解】 CF11D A Simple Task
[题解] CF11D A Simple Task 传送门 \(n \le 20\) 考虑状态压缩\(dp\). 考虑状态,\(dp(i,j,O)\)表示从\(i\)到\(j\)经过点集\(O\)的路径 ...
- Codeforces 558E A Simple Task(权值线段树)
题目链接 A Simple Task 题意 给出一个小写字母序列和若干操作.每个操作为对给定区间进行升序排序或降序排序. 考虑权值线段树. 建立26棵权值线段树.每次操作的时候先把26棵线段树上的 ...
- A Simple Task CodeForces - 11D
A Simple Task CodeForces - 11D 题意:输出一个无向图的简单环数量.简单环指无重复边的环.保证图无重边自环. ans[i][j]表示"包含i中的点,以i中第一个点 ...
- 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 ...
随机推荐
- ios audio不能够正常播放
ios中audio不能直接通过audio.play()播放,需要用户在click事件或者touch事件中执行audio.play()才能播放. ajax回调中audio.play()音乐不能正常播放. ...
- js判断json数据是否存在某字段的方法
方式一 !("key" in obj) if("name" in json){//json就是数组,name是你要找的值 console.log("有 ...
- WIN DLL劫持提权
WIN DLL劫持提权 原理: Windows程序启动的时候需要DLL.如果这些DLL 不存在,则可以通过在应用程序要查找的位置放置恶意DLL来提权.通常,Windows应用程序有其预定义好的搜索DL ...
- victoriaMetrics之byteBuffer
victoriaMetrics之byteBuffer VictoriaMetrics经常会处理数目庞大的指标,在处理的过程中会涉及指标的拷贝,如果在指标拷贝时都进行内存申请的话,其内存消耗和性能损耗都 ...
- QGIS 安装
QGIS 安装 官网 https://www.qgis.org/ 下载地址 https://www.qgis.org/en/site/forusers/download.html 参考文档 https ...
- DjangoRestFramework框架三种分页功能的实现 - 在DjangoStarter项目模板中封装
前言 继续Django后端开发系列文章.刚好遇到一个分页的需求,就记录一下. Django作为一个"全家桶"型的框架,本身啥都有,分页组件也是有的,但默认的分页组件没有对API开发 ...
- 内存之旅——如何提升CMA利用率?
(以下内容来自开发者分享,不代表 OpenHarmony 项目群工作委员会观点) 宋远征 李佳伟 OpenAtom OpenHarmony(以下简称"OpenHarmony") ...
- gin框架使用【4.请求参数】
GET url: http://127.0.0.1:8080/users?id=1&name=卷毛狒狒 package mainimport ( "github.com/gin-go ...
- android软件简约记账app开发day04-记账页面条目的代码书写
android软件简约记账app开发day04-记账页面条目的代码书写 在前三天我们完成了基本的界面展示,从今天开始,我们进入到后台逻辑代码的编写中,今天开发记账条目的代码 我们在主页面点击记一笔图标 ...
- v74.01 鸿蒙内核源码分析(编码方式篇) | 机器指令是如何编码的 | 百篇博客分析OpenHarmony源码
本篇关键词:指令格式.条件域.类型域.操作域.数据指令.访存指令.跳转指令.SVC(软件中断) 内核汇编相关篇为: v74.01 鸿蒙内核源码分析(编码方式) | 机器指令是如何编码的 v75.03 ...