51nod 1471 小S的兴趣 sqrt
小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的更多相关文章
- 51nod 1471 小S的兴趣 | 分块 链表
51nod 1471 小S的兴趣 题面 小S喜欢有趣的事.但是,每个人的兴趣都是独特的.小S热衷于自问自答.有一天,小S想出了一个问题. 有一个包含n个正整数的数组a和针对这个数组的几个问题.这些问题 ...
- 51nod1471 小S的兴趣
题目来源: CodeForces 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 320 小S喜欢有趣的事.但是,每个人的兴趣都是独特的.小S热衷于自问自答.有一天,小S想出了一个问题 ...
- 51nod 1631 小鲨鱼在51nod小学
基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 鲨鱼巨巨2.0(以下简称小鲨鱼)以优异的成绩考入了51nod小学.并依靠算法方面的特长,在班里担任了许多职务. ...
- 51nod 2489 小b和灯泡
小b有n个关闭的灯泡,编号为1...n. 小b会进行n轮操作,第i轮她会将编号为i的倍数的灯泡的开关状态取反,即开变成关,关变成开. 求n轮操作后,有多少灯泡是亮着的. 收起 输入 输入一个数字表 ...
- 51nod 1831 小C的游戏
小C和小L是好朋友,她们在玩一个游戏. 一开始有一个大小为n的石子堆,小C先手. 每次可以对这个石子堆拿走一个或者把这个石子堆分成等量的几份并只取其中一份(不能不变或只剩下一个). 如果取走最后一个人 ...
- 51nod——2489 小b和灯泡(打表/平方数)
这题打表去找因子的个数然后判奇偶也行.预处理O(n) 扫一遍判断O(n). ; i * i <= n; i++){ for(int j = i; i * j <= n; j++){ div ...
- 51nod 2486 小b和矩阵
小b有一个m行n列的矩阵. 她会从(1,1)开始,顺时针螺旋访问该矩阵,每个元素恰好被访问一次. 请你按小b的访问顺序输出每个元素. 收起 输入 第一行输入两个数m和n,其中0<m,n≤50 ...
- 51nod 2485 小b重排字符串
小b有一个字符串S,现在她希望重排列S,使得S中相邻字符不同. 请你判断小b是否可能成功. 样例解释:将"aab"重排为"aba"即可. 收起 输入 输入一 ...
- 51nod 1643 小Q的家庭作业
题意: f(n) = sigma(gcd(i,n)) 1 <= i <= n g(n) = sigma(f(d)) d | n n = x1 * x2 * ... * xm 其中 ...
随机推荐
- Android碎片使用
首先新建一个fragment的布局文件, <?xml version="1.0" encoding="utf-8"?><LinearLay ...
- post multipart data boundary问题 使用curl 向jersey post文件
原以为curl 模拟post file跟post string类似,-d参数一加 ,header一加就完了,这次遇到个问题,却怎么都搞不定. curl模拟post提交 与客户端定的协议是: Heade ...
- 收藏的牛人的Backbone分享教程
http://yujianshenbing.iteye.com/category/256978 感谢御剑神兵,目前正在看,为源码分析做准备. 今天是2015年4月13号,看了前两篇,
- [蟒蛇菜谱] Python方便使用的级联进度信息
class StepedProgress: '''方便显示进度的级联进度信息. ''' def __init__(self, stockPercent=[1], parentProgress=None ...
- 数据结构《16》----自动补齐实现《一》----Trie 树
1. 简述 Trie 树是一种高效的字符串查找的数据结构.可用于搜索引擎中词频统计,自动补齐等. 在一个Trie 树中插入.查找某个单词的时间复杂度是 O(len), len是单词的长度. 如果采用平 ...
- Windows下利用py2exe生成静默运行的命令行程序
py2exe是python的第三方库,可以利用它将你的python脚本编译成可执行文件(exe),而在实际的开发过程中生成的dos窗口很影响用户体验,建议按以下方式让exe静默运行. 首先将你的pyt ...
- 第二个Sprint冲刺项目github
https://github.com/22shaojiawen/the-second-sprint-project
- MINIX3 内核整体架构回顾及内核定 性分析
MINIX3 内核整体架构回顾及内核定 性分析 12.1 注意事项 由于本文档不对 I/O 文件系统做出分析,所以在此不对 MINIX3 整体做出一个分 析,本章主要是针对内核进程分析.并且这里的模 ...
- Linux线程-互斥锁pthread_mutex_t
在线程实际运行过程中,我们经常需要多个线程保持同步.这时可以用互斥锁来完成任务:互斥锁的使用过程中,主要有pthread_mutex_init,pthread_mutex_destory,pthrea ...
- Zookeeper源码编译为Eclipse工程(转)
原文地址:http://blog.csdn.net/jiyiqinlovexx/article/details/41179293 为了深入学习ZooKeeper源码,首先就想到将其导入到Eclispe ...