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 ...
随机推荐
- 【并发】7、借助redis 实现多线程生产消费队列
1.这是第一个简单的初始化版本,看起来比使用fqueue似乎更好用 package queue.redisQueue; import queue.fqueue.vo.TempVo; import re ...
- SSL 杂谈
在电子邮件系统中的开发和维护中,由于安全性的需要,经常会遇到 SSL 相关的问题,这里整理下 SSL 的一些基础知识 什么是 SSL SSL (Secure Sockets Layer) 是一种在应用 ...
- Account locked due to 25 failed logins
Account locked due to 25 failed logins pam_tally2 --user=ops #查看 pam_tally2 --user=ops --reset # ...
- [LOJ 6485]LJJ学二项式定理(单位根反演)
也许更好的阅读体验 \(\mathcal{Description}\) 原题链接 \(T\)组询问,每次给\(n,s,a_0,a_1,a_2,a_3\)求 \(\begin{aligned}\left ...
- 微信小程序DEMO——面包旅行的代码
API 集合在一起写了一个页面,并导出, const apiURL = 'http://xxx.xxxx.com'; const trip = { hot(data,callback){ wx.req ...
- Python遗传和进化算法框架(一)Geatpy快速入门
https://blog.csdn.net/qq_33353186/article/details/82014986 Geatpy是一个高性能的Python遗传算法库以及开放式进化算法框架,由华南理工 ...
- POJ1475(Pushing Boxes)--bbffss
题目在这里 题目一看完就忙着回忆童年了.推箱子的游戏. 假设只有一个箱子.游戏在一个R行C列的由单位格子组成的区域中进行,每一步, 你可以移动到相邻的四个格子中的一个,前提是那个格子是空的:或者,如果 ...
- 《你不知道的Javascript》感悟篇—对象属性遍历的那些事
划重点 本篇笔者将重点介绍JavaScript中 getOwnPropertyNames .Object.keys.for ... in 的使用及他们之间的异同点. getOwnPropertyNam ...
- vscode左侧栏显示
1.显示工具栏 点击文件,选择首选项,点击设置按钮 搜索workbench,勾选上Workbench> Activity Bar:Visble 勾选上后,工具栏就显示出来了 2.移动工具栏选中工 ...
- 前端编译原理 parser.js源码解读
前面已经介绍了一个jison的使用,在正常开发中其实已经够用下,下面主要是看了下parser.js代码解读下,作为一些了解. 下面以最简单的文法产生的parser做一些代码注释 下面是一些注释,标示了 ...