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 其中 ...
随机推荐
- guava学习--集合1
Lists: 其内部使用了静态工厂方法代替构造器,提供了许多用于List子类构造和操作的静态方法,我们简单的依次进行说明,如下: newArrayList():构造一个可变的.空的ArrayList实 ...
- SEO命令之”site“运用详解
一.“site”基本介绍: 都知道要想查询一个特定网站的收录状况一般会分为两种情况:一.结果中有返回数据,则表明该网站已被收录:二.如果返回数据为空,则该网站未被收录.如果是以前已被收录的,现在来查没 ...
- 使用Dottrace跟踪代码执行时间
当自己程序遇到性能问题,比如IIs请求反应缓慢,客户端程序执行缓慢,怎么分析是哪里出了问题呢?dottrace可以帮助.net程序跟踪出代码里每个方法的执行时间,这样让我们更清晰的看出是哪里执行时间过 ...
- WCF初探-14:WCF服务协定
前言: 在前面的文章中,我们定义的服务协定上都会有一个ServiceContract的特性来修饰,这是因为服务契约的实现要靠ServiceContractAttribute 属性定义,然后使用一个或多 ...
- POJ 3020 Antenna Placement 匈牙利算法,最大流解法 难度:1
http://poj.org/problem?id=3020 #include <cstdio> #include <cstring> #include <vector& ...
- 【0 - 1】OC内存管理
一.内存管理概述 垃圾回收机制(GC):由系统管理内存,程序员不需要管理. OC中的垃圾回收:在OC2.0版加入垃圾回收. OC与iOS:OC有垃圾回收机制,但是iOS屏蔽了这个功能.原因:iOS运行 ...
- android 使用相机拍照,并存储到手机sd卡上,并利用系统录像录像并播放
//首先声明一个成员变量 String savePath,用来储存文件路径 /** * 保存照片路径 * @return 返回图片的一个文件 * @throws IOException 抛出一个异常 ...
- HDU1004 BALLO0N
Let the Balloon Rise Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- C# 顺序高斯(Gauss)消去法计算一元多次方程组
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- JVM-类加载机制
虚拟机类加载机制 虚拟机把描述的类的数据从class文件加载到内存后,并对数据进行校验,转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的类加载机制. 类加载的时机 类被 ...