洛谷P2787 语文1(chin1)- 理理思维
珂朵莉树吼啊!!!
对于操作$1$,直接普通查询即可
对于操作$2$,直接区间赋值即可
对于操作$3$,其实也并不难,来一次计数排序后,依次插入即可,(注意初始化计数器数组)具体实现看代码
代码:
#include<iostream>
#include<cstdio>
#include<set>
#include<algorithm>
#include<cstring>
#define Set set<Node>::iterator
using namespace std;
struct Node
{
int l,r;
mutable char val;
Node(int L,int R,char V):l(L),r(R),val(V){}
Node(int L):l(L){}
bool operator < (const Node &it)const
{
return l<it.l;
}
};
set<Node> st;
int n,m;
int c[26];
Set Split(int x)
{
Set it=st.lower_bound(Node(x));
if(it!=st.end()&&it->l==x)
return it;
--it;
int L=it->l,R=it->r;
char V=it->val;
st.erase(it);
st.insert(Node(L,x-1,V));
return st.insert(Node(x,R,V)).first;
}
void Change(int l,int r,char v)
{
Set rr=Split(r+1),ll=Split(l);
st.erase(ll,rr);
st.insert(Node(l,r,v));
}
int Search(int l,int r,char v)
{
Set rr=Split(r+1),ll=Split(l);
int ans=0;
for(Set it=ll;it!=rr;++it)
if(it->val==v)
ans+=it->r-it->l+1;
return ans;
}
void Sort(int l,int r)
{
memset(c,0,sizeof(c));
Set rr=Split(r+1),ll=Split(l);
for(Set it=ll;it!=rr;++it)
c[it->val-'A']+=it->r-it->l+1;
st.erase(ll,rr);
int now=l;
for(int i=0;i<26;++i)
if(c[i])
{
st.insert(Node(now,now+c[i]-1,i+'A'));
now=now+c[i];
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)
{
char in;
scanf(" %c",&in);
if(in>='a'&&in<='z')
in=in-'a'+'A';
st.insert(Node(i,i,in));
}
st.insert(Node(n+1));
for(int i=1;i<=m;++i)
{
int opt,l,r;
char k;
scanf("%d%d%d",&opt,&l,&r);
if(opt==1)
{
scanf(" %c",&k);
if(k>='a'&&k<='z')
k=k-'a'+'A';
printf("%d\n",Search(l,r,k));
}
if(opt==2)
{
scanf(" %c",&k);
if(k>='a'&&k<='z')
k=k-'a'+'A';
Change(l,r,k);
}
if(opt==3)
Sort(l,r);
}
return 0;
}
洛谷P2787 语文1(chin1)- 理理思维的更多相关文章
- 2019.01.19 洛谷P2787 语文1(chin1)- 理理思维(ODT)
传送门 ODTODTODT水题. 题意:有一个字母序列,支持区间赋值,查询区间某个字母的数量,区间按字母序排序. 思路: 可以开262626棵线段树搞过去,然而也可以用ODTODTODT秒掉. 如果用 ...
- 洛谷P2787 语文1(chin1)- 理理思维(珂朵莉树)
传送门 一看到区间推倒……推平操作就想到珂朵莉树 区间推平直接assign,查询暴力,排序的话开一个桶统计,然后一个字母一个字母加就好了 开桶统计的时候忘了保存原来的左指针然后挂了233 //mina ...
- 洛谷 P2787 语文1(chin1)- 理理思维
题意简述 维护字符串,支持以下操作: 0 l r k:求l~r中k的出现次数 1 l r k:将l~r中元素赋值为k 2 l r:询问l~r中最大连续1的长度 题解思路 珂朵莉树暴力赋值,查询 代码 ...
- 洛谷AT2342 Train Service Planning(思维,动态规划,珂朵莉树)
洛谷题目传送门 神仙思维题还是要写点东西才好. 建立数学模型 这种很抽象的东西没有式子描述一下显然是下不了手的. 因为任何位置都以\(k\)为周期,所以我们只用关心一个周期,也就是以下数都在膜\(k\ ...
- 洛谷P4424 [HNOI/AHOI2018]寻宝游戏(思维题)
题意 题目链接 Sol 神仙题Orz Orz zbq爆搜70.. 考虑"与"和"或"的性质 \(0 \& 0 = 0, 1 \& 0 = 0\) ...
- 洛谷 P3955 图书管理员【模拟/思维】
题目描述 图书馆中每本书都有一个图书编码,可以用于快速检索图书,这个图书编码是一个 正整数. 每位借书的读者手中有一个需求码,这个需求码也是一个正整数.如果一本书的图 书编码恰好以读者的需求码结尾,那 ...
- 双栈排序(洛谷P1155)二分图的判定+思维贪心
题目:戳这里 题目大意: 给你一个数列,问能否通过两个栈的push与pop把它输出成一个升序序列(每个数只能入队并出队一次) 不能的话输出0,能的话输出操作方法 主要思路: 1.判断是否可以成功输出升 ...
- 洛谷 P2391.白雪皑皑 (并查集,思维)
题意:有\(n\)个点,对这些点进行\(m\)次染色,第\(i\)次染色会把区间\((i*p+q)\ mod\ N+1\)和\((i*q+p)\ mod\ N+1\)之间的点染成颜色\(i\),问最后 ...
- 洛谷P2367 语文成绩(差分)
标准的差分应用题,不要想的太复杂,写成了线段树. 1 #include<bits/stdc++.h> 2 using namespace std; 3 const int N=5e6+10 ...
随机推荐
- Windows安全日志
在运行中输入:eventvwr.msc,即可打开事件日志. 登录类型 描述 2 互动(键盘和屏幕的登录系统) 3 网络(即连接到共享文件夹从其他地方在这台电脑上网络) 4 批处理(即计划任务) 5 服 ...
- selenium登录慕课网
from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.s ...
- command not found 的解决&&解释
ln -s /opt/platform/calico/calicoctl /usr/local/sbin/calicoctl ln -s /opt/platform/nginx/sbin/nginxl ...
- javascript——onsubmit和onreset事件 和开发中常用的方式
<head> <meta charset="UTF-8"> <title></title> <script> funct ...
- RestShrap Simple REST and HTTP Client for .NET 了解
最近做一个项目,需要上传文件到文件服务器, 文件服务器是 内部的webapi形式的接口.经朋友推荐使用restshrap , 例子: //上传文件 var request=new RestClient ...
- 【Struts2】拦截器
一.概述 二.在Struts2中使用拦截器 2.1 步骤 2.2 分析拦截器原理 2.3 关于interceptor与Filter区别: 三.案例 一.概述 介绍拦截器: struts2拦截器使用的是 ...
- Win8电脑更新出现错误代码80070003的解决方法
有Win8系统用户在进行KB2894853更新时会碰到系统报错的问题,错误代码是80070003,那么在遇到这个问题的时候,我们该怎么去解决呢?下面好系统U盘启动就来告诉你相应的解决方法. Win8系 ...
- STM32L15x——ADC采集DMA数据只第一次正确(已解决)
前提:我用的芯片是STM32L系列,可能对其它STM32系列不完全适用,仅供参考! 一.问题描述 我在使用DMA方式读取单ADC单通道采集的数据时,发现只能正确的采集一次数据,后来的就一直与第一次的相 ...
- jenkins 持续集成笔记2 --- 构建 Java 项目
先说一下流程: jenkins 从 gitlab pull 代码,使用 maven 打包,然后备份原来的jar包,使用rsync同步到服务器上,重启服务. pipeline 资源去看官方中文文档 ht ...
- Java重写(Override)与重载(Overload)
方法的重写规则 参数列表必须完全与被重写方法的相同: 返回类型与被重写方法的返回类型可以不相同,但是必须是父类返回值的派生类(java5 及更早版本返回类型要一样,java7 及更高版本可以不同): ...