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 ...
随机推荐
- 2022DASCTF X SU 三月春季挑战赛 ezpop
复现一道dactf的ezpop <?php class crow { public $v1; public $v2; function eval() { echo new $this->v ...
- 【Android开发】毛玻璃效果
使用一:静态控件上使用 先附上自定义view-BlurringView public class BlurringView extends View { private int mDownsample ...
- 安卓性能测试之Lint测试
pre { direction: ltr; color: rgba(0, 0, 10, 1); text-align: left } pre.western { font-family: " ...
- JavaSE常用类之File类
File类 只用于表示文件或目录的信息,不能对文件内容进行访问. java.io.File类∶代表文件和目录.在开发中,读取文件.生成文件.删除文件.修改文件的属性时经常会用到本类. File类不能访 ...
- SpringMVC详解及SSM框架整合项目
SpringMVC ssm : mybatis + Spring + SpringMVC MVC三层架构 JavaSE:认真学习,老师带,入门快 JavaWeb:认真学习,老师带,入门快 SSM框架: ...
- String类为什么被设计成不可变类
1.享元模式: 1.共享元素模式,也就是说:一个系统中如果有多处用到了相同的一个元素,那么我们应该只存储一份此元素,而让所有地方都引用这一个元素. 2.Java中String就是根据享元模式设计的,而 ...
- 7.Arrays类
1. Arrays类 数组的工具类java.util.Arrays Arrays类中的方法都是static修饰的静态方法,使用的时候可以直接使用类名进行调用 (而不是使用对象)(是"不用&q ...
- 2021.11.11 EXKMP
2021.11.11 EXKMP https://www.luogu.com.cn/problem/P5410 下标以1开头: #include<cstdio> #include<i ...
- python基础练习题(输入三个整数x,y,z,请把这三个数由小到大输出)
day3 --------------------------------------------------------------- 实例005:三数排序 题目: 输入三个整数x,y,z,请把这三 ...
- 软件工程-UML各种图总结-精华
UML(Unified Modeling Language)是一种统一建模语言,为面向对象开发系统的产品进行说明.可视化.和编制文档的一种标准语言.下面将对UML的九种图+包图的基本概念进行介绍以 ...