链接:https://www.nowcoder.com/acm/contest/2/C
来源:牛客网

题目描述

shy有一个队列a[1], a[2],…,a[n]。现在我们不停地把头上的元素放到尾巴上。在这过程中我们会得到n个不同的队列,每个队列都是a[k],a[k+1],…,a[n],a[1],…,a[k-1]的形式。在这些队列中,我们可以找到字典序最小的。
shy无聊的时候会给队列的每个元素加一玩。但是为了使得游戏不这么无聊,shy加一以后会给每个元素模m,这样子字典序最小的序列就会变了,生活就变得有趣。
很显然这样子加m次以后,序列会变成原来的样子。所以现在shy想知道,在他没有加一前,加一时,加二时,….,加m-1时字典序最小的序列的第k(和上面的k没有关系)个元素分别是几。

输入描述:

第一行三个整数n,m,k表示序列长度,取模的数和要求的序列的第几个元素。
接下来一行n个整数表示初始序列。

输出描述:

m个整数表示答案。

输入例子:
5 6 3
1 2 1 2 3
输出例子:
1
2
3
5
5
0

-->

示例1

输入

5 6 3
1 2 1 2 3

输出

1
2
3
5
5
0

备注:

对于30%的数据,1≤n,m≤100;
对于100%的数据,1≤n,m≤50000, 1≤k≤n, 0≤a[i]<m;

题解

字符串$hash$。

每个数字都会变且仅变一次零。

如果上一次到这一次没有零产生,那么答案的位置不会改变。

否则重新寻找答案产生的位置。

两个字符串比较字典序,字符串$hash$一下,找$lcp$即可。

#include<bits/stdc++.h>
using namespace std; long long mod[2];
long long base[2];
const int maxn = 1e5 + 10;
int a[maxn], n, m, k;
long long h[2][maxn];
long long b[2][maxn];
int ans[maxn];
vector<int> g[maxn]; void init() {
mod[0] = 1e9 + 7;
mod[1] = 1e9 + 7;
base[0] = 131LL;
base[1] = 313LL;
b[0][0] = b[1][0] = 1LL;
for(int i = 1; i < maxn; i ++) {
for(int t = 0; t < 2; t ++) {
b[t][i] = b[t][i - 1] * base[t] % mod[t];
}
}
} int check(int x, int y, int len) {
if(len == 0) return 1;
if(x > y) swap(x, y);
for(int t = 0; t < 2; t ++) {
long long AA = 0, BB = 0;
if(x > 0) AA = h[t][x - 1] * b[t][len] % mod[t];
if(y > 0) BB = h[t][y - 1] * b[t][len] % mod[t];
long long A = (h[t][x + len - 1] - AA + mod[t]) % mod[t];
long long B = (h[t][y + len - 1] - BB + mod[t]) % mod[t];
if(A != B) return 0;
}
return 1;
} int ok(int x, int y, int f) {
int L = 0, R = n, pos = -1;
while(L <= R) {
int mid = (L + R) / 2;
if(check(x, y, mid)) pos = mid, L = mid + 1;
else R = mid - 1;
}
if(pos == n) return 0;
if((a[x + pos] + f) % m
< (a[y + pos] + f) % m) return 1;
return 0;
} int main() {
init();
scanf("%d%d%d", &n, &m, &k);
k --;
long long A[2];
A[0] = A[1] = 0;
for(int i = 0; i < n; i ++) {
scanf("%d", &a[i]);
a[i + n] = a[i];
g[(m - a[i]) % m].push_back(i);
}
for(int i = 0; i < 2 * n; i ++) {
for(int t = 0; t < 2; t ++) {
A[t] = A[t] * base[t] % mod[t];
A[t] = (A[t] + a[i]) % mod[t];
h[t][i] = A[t];
}
} int p = 0;
for(int i = 1; i < n; i ++) {
if(ok(i, p, 0)) p = i;
}
ans[0] = a[p + k];
for(int i = 1; i < m; i ++) {
if(g[i].size() == 0) {
ans[i] = ans[i - 1] + 1;
} else {
p = g[i][0];
for(int j = 1; j < g[i].size(); j ++) {
if(ok(g[i][j], p, i)) p = g[i][j];
}
ans[i] = (a[p + k] + i) % m;
}
}
for(int i = 0; i < m; i ++) {
printf("%d\n", ans[i]);
}
return 0;
}

牛客练习赛1 C - 圈圈的更多相关文章

  1. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

  2. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  3. 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A

    牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...

  4. 最小生成树--牛客练习赛43-C

    牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 ​ 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...

  5. 牛客练习赛28-B(线段树,区间更新)

    牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ ​ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, ​ 1 l r 询问区间[l,r]内的元素和 ​ 2 l r 询问区间[l,r]内的 ...

  6. 牛客练习赛26:D-xor序列(线性基)

    链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...

  7. [堆+贪心]牛客练习赛40-B

    传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费  x_i 的时间,同时完成第 i 个任务的时间不 ...

  8. 牛客练习赛 29 E 位运算?位运算!(线段树)

    题目链接  牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...

  9. 牛客练习赛22C Bitset

    牛客练习赛22C 一共有 n个数,第 i 个数是 xi  xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...

随机推荐

  1. 俞昆20155335《网络对抗》MSF基础应用

  2. HDU 6205 (模拟) card card card

    题目链接 Problem Description As a fan of Doudizhu, WYJ likes collecting playing cards very much. One day ...

  3. 45、文件过滤器FilenameFilter

    文件过滤器FilenameFilter JDK中提供了一个FilenameFilter的接口用来实现文件过滤功能,可以使用这个文件过滤器来实现上一节中的问题. File类中有一个带参数的list方法 ...

  4. 判断最小生成树是否为一(krustra)

    题目链接:https://vjudge.net/contest/66965#problem/K 具体思路: 首先跑一遍最短路算法,然后将使用到的边标记一下,同时使用一个数组记录每一个权值出现的次数,如 ...

  5. Django 创建第一个Project — Django学习(二)

    检查django If Django is installed, you should see the version of your installation. If it isn’t, you’l ...

  6. java.lang.IllegalArgumentException: class com.beisheng.maerte.mode.MyCouponVO declares multiple JSON fields named count

    原因是:子类和父类有相同的字段属性.解决办法:(1)将父类中的该字段去掉(不要),或者在需要打印的字段上加上注解@Expose (2):由于我报错的类都是在jar包里面,所以第一种方法不好使.只好采用 ...

  7. 【TortoiseSVN】windows中连接SVN服务器的工具

    1.下载安装包: 可以到我的服务器地址进行下载,有32和64位的安装包: http://qiaoliqiang.cn/fileDown/TortoiseSVN-1.8.8.25755-win32-sv ...

  8. 06 Frequently Asked Questions (FAQ) 常见问题解答 (常见问题)

    Frequently Asked Questions (FAQ) Origins 起源 What is the purpose of the project? What is the history ...

  9. 【前端开发】禁止微信内置浏览器调整字体大小的方法js

    微信webview内置了调整字体大小的功能,用户可以根据实际情况进行调节.但是很多移动端页面的开发都是使用rem作为单位的,字体大小改变以后,会出现页面布局错乱的情况,因此希望能够禁止微信的字体放大功 ...

  10. UFLDL 教程学习笔记(三)

    教程地址:http://ufldl.stanford.edu/tutorial/supervised/SoftmaxRegression/ logstic regression是二分类的问题,如果想要 ...