牛客练习赛1 C - 圈圈
链接:https://www.nowcoder.com/acm/contest/2/C
来源:牛客网
题目描述
输入描述:
第一行三个整数n,m,k表示序列长度,取模的数和要求的序列的第几个元素。
接下来一行n个整数表示初始序列。
输出描述:
m个整数表示答案。
输入例子:
5 6 3
1 2 1 2 3
输出例子:
1
2
3
5
5
0
-->
输入
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 - 圈圈的更多相关文章
- 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D
目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...
- 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B
牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...
- 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A
牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...
- 最小生成树--牛客练习赛43-C
牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...
- 牛客练习赛28-B(线段树,区间更新)
牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, 1 l r 询问区间[l,r]内的元素和 2 l r 询问区间[l,r]内的 ...
- 牛客练习赛26:D-xor序列(线性基)
链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...
- [堆+贪心]牛客练习赛40-B
传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费 x_i 的时间,同时完成第 i 个任务的时间不 ...
- 牛客练习赛 29 E 位运算?位运算!(线段树)
题目链接 牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...
- 牛客练习赛22C Bitset
牛客练习赛22C 一共有 n个数,第 i 个数是 xi xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...
随机推荐
- srpingboot2 session过期时间设置
springboot2 设置session过期的配置 server.servlet.session.timeout = 1800 而不再是 server.session.timeout=1800
- Java并发编程原理与实战十一:锁重入&自旋锁&死锁
一.锁重入 package com.roocon.thread.t6; public class Demo { /* 当第一个线程A拿到当前实例锁后,进入a方法,那么,线程A还能拿到被当前实例所加锁的 ...
- jQuery中的text(),html(),val()的区别
一.jquery中HTML 1. 无参html() 方法用来获取任意元素的HTML内容,如果你调用多个选定元素的.html()方法,那么其读取的只是第一个元素,换句话说:如果选择器匹配多于一个的元素, ...
- Document对象中的一些重要的属性和方法(笔记)
Document对象:每一个web浏览器窗口.标签页和框架由一个window对象所表示.每个window对象都有一个document属性引用的是Document对象,它是一个巨大的API中的核心对象, ...
- 20155330 2016-2017-2 《Java程序设计》第八周学习总结
20155330 2016-2017-2 <Java程序设计>第八周学习总结 教材学习内容总结 学习目标 了解NIO 会使用Channel.Buffer与NIO2 会使用日志API.国际化 ...
- 基本控件文档-UITextField属性
CHENYILONG Blog 基本控件文档-UITextField属性 Fullscreen UITextField属性技术博客http://www.cnblogs.com/ChenYilong ...
- [NOIP提高&洛谷P1024]一元三次方程求解 题解(二分答案)
[NOIP提高&洛谷P1024]一元三次方程求解 Description 有形如:ax3+bx2+cx+d=0 这样的一个一元三次方程.给出该方程中各项的系数(a,b,c,d 均为实数),并约 ...
- 通过Class类获取对象实例
通过Class对象获取对象的方式是通过class.newInstance()方式获取,通过调用默认构造参数实例化一个对象. /** * Created by hunt on 2017/6/27. * ...
- celery简介
目录 Celery简介 Celery架构 中间件选择 Celery序列化 简单项目 Celery简介 celery userguide 知乎大神解释celery Celery(芹菜)是基于Python ...
- 关于禁用"请停用以开发者模式运行的扩展程序"提示
有兴趣研究谷歌浏览器扩展开发,但每次开启高版本chrome都会有烦人的提示 因为我用的360急速,目前还有提示,但使用原生chrome连插件都给删了,无语