分块+deque维护 Codeforces Round #260 (Div. 1) D. Serega and Fun
4 seconds
256 megabytes
standard input
standard output
Serega loves fun. However, everyone has fun in the unique manner. Serega has fun by solving query problems. One day Fedor came up with such a problem.
You are given an array a consisting of n positive integers and queries to it. The queries can be of two types:
- Make a unit cyclic shift to the right on the segment from l to r (both borders inclusive). That is rearrange elements of the array in the following manner:a[l], a[l + 1], ..., a[r - 1], a[r] → a[r], a[l], a[l + 1], ..., a[r - 1].
- Count how many numbers equal to k are on the segment from l to r (both borders inclusive).
Fedor hurried to see Serega enjoy the problem and Serega solved it really quickly. Let's see, can you solve it?
The first line contains integer n (1 ≤ n ≤ 105) — the number of elements of the array. The second line contains n integers a[1], a[2], ..., a[n] (1 ≤ a[i] ≤ n).
The third line contains a single integer q (1 ≤ q ≤ 105) — the number of queries. The next q lines contain the queries.
As you need to respond to the queries online, the queries will be encoded. A query of the first type will be given in format: 1 l'i r'i. A query of the second type will be given in format: 2 l'i r'i k'i. All the number in input are integer. They satisfy the constraints: 1 ≤ l'i, r'i, k'i ≤ n.
To decode the queries from the data given in input, you need to perform the following transformations:
li = ((l'i + lastans - 1) mod n) + 1; ri = ((r'i + lastans - 1) mod n) + 1; ki = ((k'i + lastans - 1) mod n) + 1.
Where lastans is the last reply to the query of the 2-nd type (initially, lastans = 0). If after transformation li is greater than ri, you must swap these values.
For each query of the 2-nd type print the answer on a single line.
7
6 6 2 7 4 2 5
7
1 3 6
2 2 4 2
2 2 4 7
2 2 2 5
1 2 6
1 1 4
2 1 7 3
2
1
0
0
8
8 4 2 2 7 7 8 8
8
1 8 8
2 8 1 7
1 8 1
1 7 3
2 8 8 3
1 1 4
1 2 7
1 4 5
2
0
题目大意:给你一个长度为n的a数组,然后有2个操作
①输入l, r 把a[l],a[l+1]……,a[r]变成 a[r],a[l],a[l+1]……,a[r-1]
②输入l,r,v,求[l,r]中等于v的数有多少
且强制在线
思路:
用deque维护一个序列即可(md一个字母写错了debug一个下午加晚上,TAT)
不过我是很单纯的每次把deque里面的东西每次都取出来,所以跑了2000+ms,不过这个人的代码跑了500ms左右,大家如果要看可以学习一下:http://blog.csdn.net/blankcqk/article/details/38468729
我的代码:
//看看会不会爆int!数组会不会少了一维!
//取物问题一定要小心先手胜利的条件
#include <bits/stdc++.h>
using namespace std;
#pragma comment(linker,"/STACK:102400000,102400000")
#define LL long long
#define ALL(a) a.begin(), a.end()
#define pb push_back
#define mk make_pair
#define fi first
#define se second
#define haha printf("haha\n")
const int maxn = 1e5 + ;
int a[maxn];
deque<int> que[maxn];
int cnt[][maxn];
int n, q;
int belong[maxn], L[maxn], R[maxn], num, block; void build(){
block = sqrt(n); num = n / block;
if (n % block) num++;
for (int i = ; i <= num; i++)
L[i] = (i - ) * block + , R[i] = i * block;
R[num] = n;
for (int i = ; i <= n; i++)
belong[i] = (i - ) / block + ;
for (int i = ; i <= num; i++)
for (int j = L[i]; j <= R[i]; j++){
cnt[i][a[j]]++;
que[i].push_back(a[j]);
}
} int tmp[], t1[], t2[];
void update(int x, int y){
if (belong[x] == belong[y]){
int px = x - L[belong[x]] + ;///在原来的里面的位置
int py = y - L[belong[y]] + ;
int t = ;
while (!que[belong[x]].empty()){
tmp[++t] = que[belong[x]].front(); que[belong[x]].pop_front();
}
for (int i = ; i <= t; i++){
if (i == px) que[belong[x]].push_back(tmp[py]);
if (i == py) continue;
que[belong[x]].push_back(tmp[i]);
}
return ;
}
int px = x - L[belong[x]] + ;///在原来的里面的位置
int py = y - L[belong[y]] + ;
int tt1 = , tt2 = ;
while (!que[belong[x]].empty()){
t1[++tt1] = que[belong[x]].front(); que[belong[x]].pop_front();
}
while (!que[belong[y]].empty()){
t2[++tt2] = que[belong[y]].front(); que[belong[y]].pop_front();
}
for (int i = ; i <= tt1; i++){
if (i == px) {
que[belong[x]].push_back(t2[py]);
cnt[belong[x]][t2[py]]++;
}
que[belong[x]].push_back(t1[i]);
}
for (int i = ; i <= tt2; i++){
if (i == py) {
cnt[belong[y]][t2[i]]--;
continue;
}
que[belong[y]].push_back(t2[i]);
}
for (int i = belong[x] + ; i <= belong[y]; i++){
int val = que[i - ].back(); que[i - ].pop_back();
cnt[i - ][val]--; cnt[i][val]++;
que[i].push_front(val);
}
} int query(int x, int y, int val){
int ans = ;
if (belong[x] == belong[y]){
int lb = x + - L[belong[x]];
int rb = y + - L[belong[y]];///修改了
int t = ;
while (!que[belong[x]].empty()){
tmp[++t] = que[belong[x]].front(); que[belong[x]].pop_front();
}
for (int i = lb; i <= rb; i++) if (tmp[i] == val) ans++;
for (int i = ; i <= t; i++) que[belong[x]].push_back(tmp[i]);
return ans;
}
///对x的操作
int lb = x + - L[belong[x]], rb = R[belong[x]] + - L[belong[x]];
int t = ;
while (!que[belong[x]].empty()){
tmp[++t] = que[belong[x]].front(); que[belong[x]].pop_front();
}
for (int i = lb; i <= rb; i++) if (tmp[i] == val) ans++;
for (int i = ; i <= t; i++) que[belong[x]].push_back(tmp[i]);
//printf("ans = %d\n", ans); ///对y的操作
lb = , rb = y + - L[belong[y]];
t = ;
while (!que[belong[y]].empty()){
tmp[++t] = que[belong[y]].front(); que[belong[y]].pop_front();
}
for (int i = lb; i <= rb; i++) if (tmp[i] == val) ans++;
for (int i = ; i <= t; i++) que[belong[y]].push_back(tmp[i]);
//printf("ans = %d\n", ans); ///对整体的操作
for (int i = belong[x] + ; i < belong[y]; i++)
ans += cnt[i][val];
return ans;
} int main(){
cin >> n;
for (int i = ; i <= n; i++)
scanf("%d", a + i);
build();
cin >> q;
int lastans = ;
for (int i = ; i <= q; i++){
int ty, l, r, k;
scanf("%d%d%d", &ty, &l, &r);
l = (l + lastans - ) % n + , r = (r + lastans - ) % n + ;
if (l > r) swap(l, r);
if(ty == ){
if (l == r) continue;
update(l, r);
}
else {
scanf("%d", &k);
k = (k + lastans - ) % n + ;
printf("%d\n", lastans = query(l, r, k));
}
}
return ;
}
分块+deque维护 Codeforces Round #260 (Div. 1) D. Serega and Fun的更多相关文章
- Codeforces Round #260 (Div. 1) D. Serega and Fun 分块
D. Serega and Fun Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/455/pro ...
- DP Codeforces Round #260 (Div. 1) A. Boredom
题目传送门 /* 题意:选择a[k]然后a[k]-1和a[k]+1的全部删除,得到点数a[k],问最大点数 DP:状态转移方程:dp[i] = max (dp[i-1], dp[i-2] + (ll) ...
- 递推DP Codeforces Round #260 (Div. 1) A. Boredom
题目传送门 /* DP:从1到最大值,dp[i][1/0] 选或不选,递推更新最大值 */ #include <cstdio> #include <algorithm> #in ...
- Codeforces Round #260 (Div. 2)AB
http://codeforces.com/contest/456/problem/A A. Laptops time limit per test 1 second memory limit per ...
- Codeforces Round #260 (Div. 1) C. Civilization 并查集,直径
C. Civilization Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/455/probl ...
- Codeforces Round #260 (Div. 1) A - Boredom DP
A. Boredom Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/455/problem/A ...
- Codeforces Round #260 (Div. 1) A. Boredom (简单dp)
题目链接:http://codeforces.com/problemset/problem/455/A 给你n个数,要是其中取一个大小为x的数,那x+1和x-1都不能取了,问你最后取完最大的和是多少. ...
- 暴力+树状数组维护 Codeforces Round #378 (Div. 2) C
题目大意:给你一个长度为n的数组a,然后数值大的可以合并数值小的,且合并了以后该数组的长度-1.给你一个长度为k目标数组b,问,是否可以从a数组变到b数组,是就yes并且输出步骤.否就输出no 思路: ...
- Codeforces Round #260 (Div. 1) 455 A. Boredom (DP)
题目链接:http://codeforces.com/problemset/problem/455/A A. Boredom time limit per test 1 second memory l ...
随机推荐
- 缓存-MemoryCache Class
这是使用MemoryCache缓存的一个例子. private void btnGet_Click(object sender, EventArgs e) { ObjectCache cache = ...
- Oracle win64_12g 安装
1.Oracle win64_12g 安装 1.下载安装包:这里需要自己注册一下,然后就可以登录下载软件了. 下载地址: http://www.oracle.com/technetwork/datab ...
- 使用qemu-img创建虚拟磁盘文件
# 安装qemu-img yum install -y qemu-img # 获取帮助 qemu-img --help # 支持的虚拟磁盘文件格式 Supported formats: vvf ...
- 【vue】this与that 一个坑
[转载自]:https://blog.csdn.net/qq_30378229/article/details/78429374 在Vue中this始终指向Vue,但axios中this为undefi ...
- promise你懂了吗?
你能答对几题? 题目一 const promise = new Promise((resolve, reject) => { console.log(1) resolve() console.l ...
- idea 复制数据库查询结果,粘贴直接生成insert into 语句
遇到一个场景,需要将数据库查询的结果导入到另外一个数据库中,给我的第一感受是,写程序,从数据库A中获取到数据,在插入到数据库B中. 但是Idea 可以直接复制查询结果,然后粘贴生成insert语句. ...
- 第104天:web字体图标使用方法
字体图标经常使用的是 阿里图标库的:http://www.iconfont.cn/ icomoon图标库的:https://icomoon.io/ 一.阿里库字体图标使用 第一步: 首先进入阿里巴巴矢 ...
- NoSQL - Redis应用场景
问题的引入 DB(Oracle.MySQL.Postgresql等)+Memcached 这种架构模式在我们生产环境中十分常见,一般我们通过Memcached将热点数据加载到cache,应用 ...
- C#中string[]数组和list<string>泛型的相互转换 【转】
http://www.cnblogs.com/szjdw/archive/2012/03/09/2387885.html 1,从System.String[]转到List<System.Stri ...
- 【刷题】BZOJ 5248 [2018多省省队联测]一双木棋
Description 菲菲和牛牛在一块n行m列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手.棋局开始时,棋盘上没有任何棋子, 两人轮流在格子上落子,直到填满棋盘时结束.落子的规则是:一个格子可以落子 ...