CodeForces - 455D
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.
Output
For each query of the 2-nd type print the answer on a single line.
Examples
- 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
分块+双端队列
每次更新对每块进行操作:
1.中间的整块:取出最后一个放入下一块的前端;
2.两端的块:左边的块放入给定右边界位置的数字,右端的块删除给定右边界位置的数字
每次询问:
中间的整块直接查询,两边的块遍历可访问的位置;
- #include <cstdio>
- #include <stack>
- #include <cmath>
- #include <queue>
- #include <string>
- #include <queue>
- #include <cstring>
- #include <iostream>
- #include <algorithm>
- #define lid id<<1
- #define rid id<<1|1
- #define closein cin.tie(0)
- #define scac(a) scanf("%c",&a)
- #define scad(a) scanf("%d",&a)
- #define print(a) printf("%d\n",a)
- #define debug printf("hello world")
- #define form(i,n,m) for(int i=n;i<m;i++)
- #define mfor(i,n,m) for(int i=n;i>m;i--)
- #define nfor(i,n,m) for(int i=n;i>=m;i--)
- #define forn(i,n,m) for(int i=n;i<=m;i++)
- #define scadd(a,b) scanf("%d%d",&a,&b)
- #define memset0(a) memset(a,0,sizeof(a))
- #define scaddd(a,b,c) scanf("%d%d%d",&a,&b,&c)
- #define scadddd(a,b,c,d) scanf("%d%d%d%d",&a,&b,&c,&d)
- #define INF 0x3f3f3f3f
- #define maxn 100005
- typedef long long ll;
- using namespace std;
- //---------AC(^-^)AC---------\\
- deque<int>::iterator it;
- struct node
- {
- deque<int> q;
- int num[maxn];
- }block[];
- int n, m, blo, ans;
- int pos[maxn];
- void update(int a, int b)
- {
- if (pos[a] == pos[b])
- {
- it = block[pos[b]].q.begin() + ((b-)%blo);
- int tmp = *it;
- block[pos[b]].q.erase(block[pos[b]].q.begin() + ((b-)%blo));
- block[pos[b]].q.insert(block[pos[a]].q.begin() + ((a-)%blo), tmp);
- }
- else
- {
- it = block[pos[b]].q.begin() + ((b-)%blo);
- int tmp = *it;
- block[pos[b]].num[tmp]--;
- block[pos[b]].q.erase(block[pos[b]].q.begin() + ((b-)%blo));
- for (int i = pos[a]; i < pos[b]; i++) {
- int x = block[i].q.back();
- block[i].q.pop_back();
- block[i].num[x]--;
- block[i + ].q.push_front(x);
- block[i + ].num[x]++;
- }
- block[pos[a]].q.insert(block[pos[a]].q.begin() + ((a-)%blo), tmp);
- block[pos[a]].num[tmp]++;
- }
- }
- void query(int a, int b, int c)
- {
- ans=;
- if (pos[a] == pos[b])
- {
- for (it = block[pos[a]].q.begin() + ((a-)%blo); it <= block[pos[a]].q.begin() + ((b-)%blo); it++)
- if ((*it) == c) ans++;
- }
- else {
- for (int i = pos[a] + ; i < pos[b]; i++) ans += block[i].num[c];
- for (it = block[pos[a]].q.begin() + ((a-)%blo); it < block[pos[a]].q.end(); it++)
- if ((*it) == c) ans++;
- for (it = block[pos[b]].q.begin(); it <= block[pos[b]].q.begin() + ((b-)%blo); it++)
- if ((*it) == c) ans++;
- }
- printf("%d\n", ans);
- }
- int main()
- {
- scad(n);
- blo = sqrt(n);
- if (n%blo) blo++;
- forn(i, , n) pos[i] = (i - )/blo + ;
- forn(i, , n) {
- int x;
- scad(x);
- int s = pos[i];
- block[s].q.push_back(x);
- block[s].num[x]++;
- }
- scad(m);
- ans = ;
- while (m--)
- {
- int op;
- scad(op);
- if (op == )
- {
- int l, r;
- scadd(l, r);
- l = (l + ans - ) % n+;
- r = (r + ans - ) % n+;
- if (l > r) swap(l, r);
- update(l, r);
- }
- else
- {
- int l, r, k;
- scaddd(l, r, k);
- l = (l + ans - ) % n + ;
- r = (r + ans - ) % n + ;
- k = (k + ans - ) % n + ;
- if (l > r) swap(l, r);
- query(l, r, k);
- }
- }
- return ;
- }
CodeForces - 455D的更多相关文章
- CodeForces 455D 分块
题目链接:http://codeforces.com/problemset/problem/455/D 题意:给定一个长度为n的序列a[]. m次操作.共有两种操作 1 l r:将序列的a[l].a[ ...
- Serega and Fun Codeforces - 455D || queue
https://codeforces.com/problemset/problem/455/D 其实方法很多,然而当初一个也想不到... 1.分块,块内用链表维护 修改[l,r]就当成删除第r个元素, ...
- Serega and Fun CodeForces - 455D (分块 或 splay)
大意:给定n元素序列, 2种操作 将区间$[l,r]$循环右移1位 询问$[l,r]$中有多少个等于k的元素 现在给定q个操作, 输出操作2的询问结果, 强制在线 思路1: 分块 每个块内维护一个链表 ...
- Codeforces 455D 分块+链表
题意: 给定一个长度为 N 的序列两种操作1 l r 将[l,r]的数向右循环移位 2 l r 询问[l,r]内有多少个数等于 k其中 N,Q≤105,ai≤N 强制在线 思路: 1. 每块用一个链表 ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
随机推荐
- 5、zabbix使用进阶(01)
详细描述user parameters.定义主机发现规则实现自动发现.如何定义和实现自动注册方式 zabbix常用术语 1.主机(host):要监控的网络设备,可有IP或DNS名称指定: 2.主机组( ...
- css 两端对其
大段的文字直接写会有不整齐的现象 所以ui小姐姐就会和我们讲你能不能把两端对其呀 ps里面就可以呀 okok 那就两端对其好了 text-align:justify 效果为⬇️⬇️⬇️ 上面是 ...
- 对啊英语音标---二、ghywr这些辅音怎么发音
对啊英语音标---二.ghywr这些辅音怎么发音 一.总结 一句话总结:对比法,和汉语拼音做对比 对比法,和汉语拼音做对比 1.清辅音和浊辅音的区别是什么? 清辅音-[不需要声带震动]就能发出的音节: ...
- Ajax+Struts2用户注册功能实现
详细请参考源码(Github):https://github.com/QQ3330447288/ajaxRegister 1.目录结构 2.截图 3.核心代码: register.jsp <sc ...
- 4、NFS
一.NFS简介 4.1.1:什么是NFS NFS(Network File System,网络文件系统)是由SUN公司开发,并于1984年推出的技术,通过使用NF,用户和程序可以向访问本地文件一样访问 ...
- C++将十进制数转化为二进制
#include<iostream> using namespace std; void main() { ; ]; cin>>n; i=n; while(i) { a[j]= ...
- input 标签的 disabled 和 readonly 属性
首先这两种属性都会使显示出来的文本框不能输入. disabled 属性:规定禁用 input 元素.被禁用的 input 元素既不可用,也不可点击和编辑,使用 tab 键时将会被跳过,用户的所有操作对 ...
- createDocumentFragment() 方法
//createdocumentfragment()方法创建了一虚拟的节点对象,节点对象包含所有属性和方法. //当你想提取文档的一部分,改变,增加,或删除某些内容及插入到文档末尾可以使用create ...
- JDBC数据库连接工具
什么是JDBC? JDBC是一种可以执行sql语句的Java API,提供对数据库的访问方法. 什么是JDBC驱动? JDBC连接数据库需要驱动,驱动是两个设备要进行通信,满足一定的数据驱动格式.一般 ...
- 跟随我在oracle学习php(5)
框架(把一个页面引入当前页面 易维护 扩展 复用)<iframe src=”” frameborder=“”> 格式:iframe <frameset> <frame&g ...