8.1.T1
string
题面什么的
抱歉,被我咕咕咕了
考场思路:
sort大法好
n2log2n过 40% 令人着实兴奋
正解:
线段树+桶
利用只有26个字母的优势
好吧,26个字母,只怪我没想到
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define l(k) (k<<1)
#define r(k) (l(k)|1)
const int maxn=1e5+5;
struct tree{
int l,r,sum;
}t[maxn<<5];
int a[maxn];
int n,m,bj[maxn],b[27];
void upc(int k)
{
if(t[k].l==t[k].r)
return;
t[k].sum=(t[l(k)].sum==t[r(k)].sum?t[l(k)].sum:0);
}
void build(int k,int l,int r)
{
/*cout<<k<<" "<<l<<" "<<r<<endl;*/
t[k].l=l,t[k].r=r;
if(l==r)
{
t[k].sum=a[l];
bj[l]=k;
return;
}
int mid=(l+r)>>1;
build(l(k),l,mid);
build(r(k),mid+1,r);
upc(k);
}
void cl(int k)
{
if(!t[k].sum) return;
if(t[k].l!=t[k].r) t[l(k)].sum=t[r(k)].sum=t[k].sum;
}
void add(int k,int p,int l,int r)
{
if((t[k].l>=l&&t[k].r<=r)||t[k].sum==p)
{
t[k].sum=p;
cl(k);
return;
}
cl(k);
int mid=(t[k].l+t[k].r)>>1;
if(l<=mid) add(l(k),p,l,r);
if(r>mid) add(r(k),p,l,r);
upc(k);
}
void cha(int k,int l,int r)
{
/*cout<<k<<" "<<l<<" "<<r<<endl;*/
cl(k);
if(l>t[k].r||r<t[k].l)
return;
if(l<=t[k].l&&t[k].r<=r&&t[k].sum)
{
b[t[k].sum]+=t[k].r-t[k].l+1;
return;
}
cl(k);
int mid=(t[k].l+t[k].r)>>1;
if(l<=mid) cha(l(k),l,r);
if(r>mid) cha(r(k),l,r);
}
void work(int k,int l,int r)
{
memset(b,0,sizeof(b));
cha(1,l,r);
/*for(int q=1;q<=26;q++)
if(b[q])
cout<<(char)(q+'a'-1)<<" "<<b[q]<<endl;*/
int tmp=l;
if(k)
{
for(int q=1;q<=26;q++)
if(b[q])
add(1,q,tmp,tmp+b[q]-1),tmp+=b[q];
}
else
for(int q=26;q>=1;q--)
if(b[q])
add(1,q,tmp,tmp+b[q]-1),tmp+=b[q];
}
void down(int k)
{
cl(k);
if(t[k].l==t[k].r) return;
down(l(k)),down(r(k));
}
int main()
{
cin>>n>>m;
for(int q=1;q<=n;q++)
{
char ch=getchar();
while(ch<'a'||ch>'z')
ch=getchar();
a[q]=ch-'a'+1;
}
build(1,1,n);
for(int q=1,x,y,z;q<=m;q++)
cin>>x>>y>>z,work(z,x,y);
down(1);
for(int q=1;q<=n;q++)
putchar(t[bj[q]].sum+'a'-1);
puts("");
}
8.1.T1的更多相关文章
- T1加权像(T1 weighted image,T1WI)
T1加权成像(T1-weighted imaging,T1WI)是指这种成像方法重点突出组织纵向弛豫差别,而尽量减少组织其他特性如横向弛豫等对图像的影响. 弛豫:物理用语,从某一个状态恢复到平衡态的过 ...
- 关于2016.12.12——T1的反思:凸包的意义与应用
2016.12.12 T1 给n个圆,保证圆圆相离,求将圆围起来的最小周长.n<=100 就像上图.考场上,我就想用切线的角度来做凸包.以圆心x,y排序,像点凸包一样,不过用两圆之间的下切线角度 ...
- T2 Func<in T1,out T2>(T1 arg)
委托调用方法的4种方式. using System; using System.Collections.Generic; namespace ConsoleApplication1 { delegat ...
- E1、T1链路
北美的24路脉码调制PCM简称T1 速率是1.544Mbit/s 北美使用的T1系统共有24个话路,每个话路采样脉冲用7bit编码,然后再加上1位信令码元,因此一个话路占用8bit. 帧同步码是在24 ...
- Action<T1, T2>委托
封装包含两个参数的方法委托,没有返回值. 语法 public delegate void Action<in T1, in T2>( T1 arg1, T2 arg2 ) 类型参数 in ...
- 有三个线程T1 T2 T3,如何保证他们按顺序执行-转载
T3先执行,在T3的run中,调用t2.join,让t2执行完成后再执行t3 在T2的run中,调用t1.join,让t1执行完成后再让T2执行 public class Test { // 1.现在 ...
- 现在有T1、T2、T3三个线程,怎样保证T2在T1执行完后执行,T3在T2执行完后执行?使用Join
public class TestJoin { public static void main(String[] args) { Thread t1 = new Thread(new T1(), &q ...
- 【测试】在hr用户下自行创建T1和T2表写一条SQL语句,(NL连接)
SQL> select t1.* from t1,t2 where t1.object_id=t2.object_id; rows selected. Execution Plan ------ ...
- MRI中T1和T2的含义与区分[转]
A. MRI名词解释 T1加权像.T2加权像为磁共振检查中报告中常提到的术语,很多非专业人士不明白是什么意思,要想认识何为T1加权像.T2加权像,请先了解几个基本概念: 1.磁共振(maget ...
- noip2015day1 T1 4510 神奇的幻方
4510 神奇的幻方 noip2015day1 T1 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descripti ...
随机推荐
- Scratch编程:初识Scratch及编程工具安装(一)
“ Scratch是一款由美国麻省理工学院(MIT)设计开发的少儿编程工具.” Scratch采用可视化.模块化的编程方式,非常适合青少年作为初次接触编程的工具和语言来学习,进而用其编写充满趣味的小程 ...
- 音视频入门-08-RGB&YUV
* 音视频入门文章目录 * YUV & RGB 相互转换公式 YCbCr 的 Y 与 YUV 中的 Y 含义一致,Cb 和 Cr 与 UV 同样都指色彩,Cb 指蓝色色度,Cr 指红色色度,在 ...
- [转载] jmeter Bean Shell的使用
Jmeter有哪些Bean Shell 定时器: BeanShell Timer 前置处理器:BeanShell PreProcessor 采样器: BeanShell Sampler 后置处理器:B ...
- C#,WinForm文本框录入内容判断
|| e.KeyChar > ) && (e.KeyChar != ) && (e.KeyChar != ) && (e.KeyChar != ) ...
- SQL根据指定节点ID获取所有父级节点和子级节点(转载)
--根据指定节点ID获取所有子节点-- WITH TEMP AS ( ' --表的主键ID UNION ALL SELECT T0.* FROM TEMP,table_name T0 WHERE TE ...
- hive分区理念介绍
一.背景 1.在Hive Select查询中一般会扫描整个表内容,会消耗很多时间做没必要的工作.有时候只需要扫描表中关心的一部分数据,因此建表时引入了partition概念. 2.分区表指的是在创建表 ...
- 【问题】root账号的UID和GID永远是0吗?
参考:Does the root account always have UID/GID 0? 这实际上是2个问题 Does the superuser account always have uid ...
- LPCXpresso54608开发板中文用户手册
M11035 LPCXpresso54608/54618/54S618开发板用户手册 1. 简介 LPCXpresso系列电路板为恩智浦LPC Cortex-M系列微控制器提供了强大而灵 ...
- 使用Arduino开发板控制步进电机
目前为止,我还没有真正深入了解过电机,特别是步进电机. 最近我在计划一个项目,需要相对精确的电机控制,所以可能会使用到步进电机,但很快就意识到我首先应该更多地了解这些. 本篇文章主要介绍我到目前为止学 ...
- unable to access 'https://github.com/shixianqing/img.git/': SSL connect error 解决办法
解决在linux环境下,git clone 项目,走https协议时,报SSL connect error 错误 升级nss yum update -y nss curl libcurl