Queries on a String

Posted -ackerman

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Queries on a String相关的知识,希望对你有一定的参考价值。

题意:

给你一个字符串s,接着有m次循环移位。
  循环移位的一个操作就是将s的最后一个字符移动到第一个字符的位置,并且将所有其他的字符向右移动一个位置。
  例如,s=‘abacaba‘,查询是L1=3,R1=6,K1=1,那么答案是’abbacaa’(解释:从s第三个位置到第六个位置’acab’,循环1次,把b移到第一位,其他往后移一位,就是’baca’,替换之前的’acab’),之后如果我们再做处理L2=1,R2=4,K2=2,那么答案就变’baabcaa’(解释:首先从第一个位置到第四个位置’abba’,第一次通过移位得到’aabb’,第二次就得到’baab’,替换之前的’abba’)。
  
输入格式:
  第一行一个字符串s,(1<=s的长度<=10000),s全是小写字母;
  第二行一个整数m,有m个查询;
  接下来有m行,包含三个整数Li,Ri,  Ki(1<=Li<=Ri<=s的长度,Ki<=1000000)。

 输出格式
  输出经过m个查询的s。

 

思路:

如果是真的暴力(模拟每一步的改变) 那真的会超时!

关键还是利用好 k 和区间长度之间的关系

 

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <stdlib.h>
 4 #include <cstring>
 5 #include <string>
 6 #include <string.h>
 7 #include <set>
 8 #include <queue>
 9 #include <stdbool.h>
10 
11 #define LL long long
12 using namespace std;
13 const int maxn = 1e5 + 10;
14 
15 int main()
16 
17     string s1,s2;
18     cin>>s1;
19     s2=s1;
20     int q;
21     cin>>q;
22     while(q--)
23     
24         int l,r,k;
25         cin>>l>>r>>k;
26         l--,r--;
27         int len = r-l+1;
28         k%=len;
29         for(int i=0;i<len;i++)
30         
31             s2[(i+k)%len+l]=s1[l+i]; // 这一步是关键
32         
33         for(int i=l;i<=r;i++)
34             s1[i]=s2[i];
35     
36     cout<<s1<<endl;
37 

 

以上是关于Queries on a String的主要内容,如果未能解决你的问题,请参考以下文章

UVA - 12424 Answering Queries on a Tree(十棵线段树的树链剖分)

CH4301 Can you answer on these queries III 题解

[线段树]校OJ-Can you answer on these queries III

CodeForces 1114F--Please, another Queries on Array?(欧拉函数+线段树)

[codeforces]Round #538 (Div. 2) F. Please, another Queries on Array?

CF1114F Please, another Queries on Array?(线段树,数论,欧拉函数,状态压缩)