小S喜欢有趣的事。但是,每个人的兴趣都是独特的。小S热衷于自问自答。有一天,小S想出了一个问题。

有一个包含n个正整数的数组a和针对这个数组的几个问题。这些问题有两种类型:

1.      在数组下标l到r的部分上,将一个单元格循环移动到右端。即以下面方式重新分配数组上的元素。

a[l], a[l+1], ..., a[r-1], a[r] → a[r], a[l], a[l+1], ..., a[r-1].

2.      在数组下标l到r的部分上,计算有多少元素的值与k相等。

小S很喜欢这个问题并且很快解决了它,你是否能够解决它呢?

分块,每一个块维护一个链表,也可以用数组模拟,不包含整个区间就暴力更改。

O(nsqrt(n))

右移相当于在末尾删除一个元素,在首部添加一个元素。

debug了很久,原因:在解密l,r,k,后,有可能l > r,这个时候要swap(l,r)

代码:

  //File Name: nod1471.cpp
//Author: long
//Mail: 736726758@qq.com
//Created Time: 2016年09月15日 星期四 21时17分30秒 #include <stdio.h>
#include <string.h>
#include <algorithm>
#include <iostream>
#include <map>
#define LL long long
using namespace std;
const int MAXN = + ;
const int NUM = ;
int l[MAXN/NUM+],r[MAXN/NUM+],belong[MAXN];
int a[MAXN],tmp[NUM],cnt;
struct Block{
int b[NUM],s[MAXN],head,tot;
void build(const int l,const int r){
tot = head = ;
memset(s,,sizeof s);
for(int i=l;i<=r;i++){
b[tot++] = a[i];
s[a[i]]++;
}
}
void right(int st){
head--;
if(head < ) head = tot - ;
cnt = b[head];
s[cnt]--;
b[head] = st;
s[st]++;
}
void reset(){
if(head == ) return ;
for(int i=;i<tot;i++) tmp[i] = b[i];
int u = ;
for(int i=head;i<tot;i++) b[u++] = tmp[i];
for(int i=;i<head;i++) b[u++] = tmp[i];
head = ;
}
void brute(int st,int l,int r){
reset();
cnt = b[r];
s[cnt]--;
for(int i=r;i>l;i--) b[i] = b[i-];
b[l] = st;
s[st]++;
}
int get(int k){
k = (head + k) % tot;
return b[k];
}
int query(int k){
return s[k];
}
int cal(int l,int r,int k){
reset();
int res = ;
for(int i=l;i<=r;i++)
if(b[i] == k) res++;
return res;
}
}block[MAXN / NUM + ];
void solve(int n){
for(int i=;i<=n;i++)
belong[i] = (i - ) / NUM;
int tot = belong[n] + ,u=;
for(int i=;i<tot;i++,u+=NUM){
l[i] = u;
r[i] = min(u + NUM - ,n);
}
for(int i=;i<tot;i++)
block[i].build(l[i],r[i]);
int ans = ,q,op,x,y,k;
scanf("%d",&q);
while(q--){
scanf("%d %d %d",&op,&x,&y);
if(op == ){
x = (x + ans - ) % n + ;
y = (y + ans - ) % n + ;
if(x > y) swap(x,y);
int bx = belong[x],by = belong[y];
if(bx == by){
cnt = block[bx].get(y-l[bx]);
block[bx].brute(cnt,x-l[bx],y-l[bx]);
}
else{
cnt = block[by].get(y-l[by]);
block[bx].brute(cnt,x-l[bx],r[bx]-l[bx]);
for(int i=bx+;i<by;i++)
block[i].right(cnt);
block[by].brute(cnt,,y-l[by]);
}
}
else{
scanf("%d",&k);
x = (x + ans - ) % n + ;
y = (y + ans - ) % n + ;
k = (k + ans - ) % n + ;
if(x > y) swap(x,y);
//cout << x << " " << y << " " << k << " " << endl;
int bx = belong[x],by = belong[y];
ans = ;
if(bx == by)
ans = block[bx].cal(x-l[bx],y-l[bx],k);
else{
ans += block[bx].cal(x-l[bx],r[bx]-l[bx],k);
for(int i=bx+;i<by;i++)
ans += block[i].query(k);
ans += block[by].cal(,y-l[by],k);
}
printf("%d\n",ans);
}
}
}
int main(){
int n;
while(~scanf("%d",&n)){
for(int i=;i<=n;i++) scanf("%d",a + i);
solve(n);
}
return ;
}

51nod 1471 小S的兴趣 sqrt的更多相关文章

  1. 51nod 1471 小S的兴趣 | 分块 链表

    51nod 1471 小S的兴趣 题面 小S喜欢有趣的事.但是,每个人的兴趣都是独特的.小S热衷于自问自答.有一天,小S想出了一个问题. 有一个包含n个正整数的数组a和针对这个数组的几个问题.这些问题 ...

  2. 51nod1471 小S的兴趣

    题目来源: CodeForces 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 320 小S喜欢有趣的事.但是,每个人的兴趣都是独特的.小S热衷于自问自答.有一天,小S想出了一个问题 ...

  3. 51nod 1631 小鲨鱼在51nod小学

    基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 鲨鱼巨巨2.0(以下简称小鲨鱼)以优异的成绩考入了51nod小学.并依靠算法方面的特长,在班里担任了许多职务.   ...

  4. 51nod 2489 小b和灯泡

    小b有n个关闭的灯泡,编号为1...n. 小b会进行n轮操作,第i轮她会将编号为i的倍数的灯泡的开关状态取反,即开变成关,关变成开. 求n轮操作后,有多少灯泡是亮着的. 收起   输入 输入一个数字表 ...

  5. 51nod 1831 小C的游戏

    小C和小L是好朋友,她们在玩一个游戏. 一开始有一个大小为n的石子堆,小C先手. 每次可以对这个石子堆拿走一个或者把这个石子堆分成等量的几份并只取其中一份(不能不变或只剩下一个). 如果取走最后一个人 ...

  6. 51nod——2489 小b和灯泡(打表/平方数)

    这题打表去找因子的个数然后判奇偶也行.预处理O(n) 扫一遍判断O(n). ; i * i <= n; i++){ for(int j = i; i * j <= n; j++){ div ...

  7. 51nod 2486 小b和矩阵

    小b有一个m行n列的矩阵. 她会从(1,1)开始,顺时针螺旋访问该矩阵,每个元素恰好被访问一次. 请你按小b的访问顺序输出每个元素. 收起   输入 第一行输入两个数m和n,其中0<m,n≤50 ...

  8. 51nod 2485 小b重排字符串

    小b有一个字符串S,现在她希望重排列S,使得S中相邻字符不同. 请你判断小b是否可能成功. 样例解释:将"aab"重排为"aba"即可. 收起   输入 输入一 ...

  9. 51nod 1643 小Q的家庭作业

    题意: f(n) = sigma(gcd(i,n))  1 <= i <= n g(n) = sigma(f(d))    d | n n = x1 * x2 * ... * xm 其中 ...

随机推荐

  1. PostgreSQL的时间/日期函数使用 转

    http://www.cnblogs.com/mchina/archive/2013/04/15/3010418.html

  2. loading

    <!doctype html> <html> <head> <title>实惠福利</title> <meta charset=&qu ...

  3. HBase Cassandra Riak HyperTable

    Cassandra                                                              HBase 一致性 Quorum NRW策略 通过Goss ...

  4. GCD与block

    GCD技术多线程编程的三个技术  NSThread NSOperation GCD1.GCD(Grand central Dispatch:宏大的中央调度)        1) 是用纯C语言实现的.提 ...

  5. Invoke-WebRequest Invoke-RestMethod 乱码研究

    powershell Invoke-WebRequest Invoke-RestMethod 乱码 encoding sharset CharacterSet Invoke-WebRequest和In ...

  6. css2----清除浮动

    为什么要清除浮动? 非IE下,当容器的高度为auto,容器有浮动元素,此时容器的高度不能自己伸长适应内容的高度,造成内容溢出乃至影响布局,即所谓的“浮动溢出”,为防此象,需要清除浮动. 如何清除浮动? ...

  7. Android Studio实现页面跳转(新页面或者网站)

    一,跳转到另一个页面 百度了好久,好像好多种方法,从中挑选了一中比较方便的一中方法 利用Intent类进行实现 1,首先在firstActivity中添加相应的跳转命令代码 例如一下示例代码 if ( ...

  8. android sdk 更新用的HOSTS

    74.125.113.121 developer.android.com203.208.46.146 www.google.com 203.208.46.146 dl.google.com 203.2 ...

  9. Python操作文件文档

    需要帮老师将44G的图书分类一下,人工当然累死了.所以用Python大法处理一下. 思路是读取文件目录下的书名,然后去百度百科查分类,如果还没有就去豆瓣,当当查.哪一个先找到其余的就不用找了.如果没有 ...

  10. SCons - 简单而强大的项目编译脚本

    N年前学的makefile,当时还勉强能写一些简单的工程编译,现在已经基本忘了.makefile确实编写复杂,而且平时也不是经常使用,容易忘记.偶识了scons,一切都变的简单了.最近研究了下scon ...