2018年多校第三场第一题 A. Ascending Rating hdu6319
比赛地址:http://acm.hdu.edu.cn/contests/contest_show.php?cid=804
题目编号:第一题 A. Ascending Rating hdu6319
题意:
给定一个序列 a[1..n],对于每个长度为 m 的连续子区间, 求出区间 a 的最大值以及从左往右扫描该区间时 a 的最大值的 变化次数。
题解:按照 r 从 m 到 n 的顺序很难解决这个问题。 考虑按照 r 从 n 到 m 的顺序倒着求出每个区间的答案。 按照滑窗最大值的经典方法维护 a 的单调队列,那么队列 中的元素个数就是最大值的变化次数。 时间复杂度 O(n)。
我的理解:由于从前向后的顺序来做的话,当窗口向后滑动一格时,当前L的值若比L-1的值小的话,那么可能会出现之前没有在队列里的值需要重新进队的情况,所以很难做到O(n),ljj虽然有想法,但是直观上来看,从后向前的顺序更简单一点。因为每次向前滑动一格,队头如果是R,那么去掉队头,如果不是R那么R值对后面也没有用且R值本身并没有在队列中,所以是O(1),对于L,将L值插入单调队列并设置为新的队尾即可,新队尾之前的部分在之后不可能再用到,所以每个值最多只可能在队列中被新增和删除一次,所以平均每个窗口滑动对于L值得操作也是O(1)的。队列就开个足够大数组往后挪就好了,懒得写循环队列了。然后取模本身是很慢的操作,尽量少取模吧(删了几个%就ac了)。。。
自己的代码还是参考了下题解的:
#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<cmath>
using namespace std;
int T;
long long n,m,k,p,q,r,MOD;
long long a[];
long long q1[];
long long ans1,ans2;
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%lld%lld%lld%lld%lld%lld%lld",&n,&m,&k,&p,&q,&r,&MOD);
for(int i=;i<=k;i++)
scanf("%lld",&a[i]);
for(int i=k+;i<=n;i++)
{
a[i]=(((p*a[i-])+(q*i))+r)%MOD;
}
int top=;//用来记录当前单调队列队顶的位置,因为数组大于总共的ai的个数,所以不需要每次把新队列整理,而是动态的用这个空间,记录当前队列的队顶队尾即可。
int rec=;//队尾的位置
for(int i=n;i>=n-m+;i--)
{
while(rec>=top&&a[i]>=a[q1[rec]])rec--;
rec++;
q1[rec]=i;
}
ans1+=a[q1[top]]^(n-m+);
ans2+=(rec-top+)^(n-m+);
int i=n-m;
for(int l=n-m;l>=;l--)
{
int r=l+m-;
if(r+==q1[top])//当新区间不包括当前队顶时,则更新队列,去掉队顶,队尾前移。
{
top++;
}
while(rec>=top&&a[l]>=a[q1[rec]])rec--;
rec++;
q1[rec]=i;
ans1+=a[q1[top]]^i;
ans2+=(rec-top+)^i;
i--;
}
printf("%lld %lld\n",ans1,ans2);
ans1=ans2=;
q1[]=;
}
}
2018年多校第三场第一题 A. Ascending Rating hdu6319的更多相关文章
- 2018 HDU多校第三场赛后补题
2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...
- 2019年杭电多校第三场 1011题Squrirrel(HDU6613+树DP)
题目链接 传送门 题意 给你一棵无根树,要你寻找一个根节点使得在将一条边权变为\(0\)后,离树根最远的点到根节点的距离最小. 思路 本题和求树的直径很像,不过要记得的东西有点多,且状态也很多. \( ...
- [题解]Magic Line-计算几何(2019牛客多校第三场H题)
题目链接:https://ac.nowcoder.com/acm/contest/883/H 题意: 给你偶数个点的坐标,找出一条直线将这n个点分成数量相等的两部分 并在这条直线上取不同的两个点,表示 ...
- [题解] 2019牛客暑期多校第三场H题 Magic Line
题目链接:https://ac.nowcoder.com/acm/contest/883/H 题意:二维平面上有n个不同的点,构造一条直线把平面分成两个点数相同的部分. 题解:对这n个点以x为第一关键 ...
- 2018年多校第四场第二题 B. Harvest of Apples hdu6333
题意:给定10^5以内的n,m求∑组合数(n,i),共10^5组数据. 题解: 定义 S(n, m) = \sum_{i = 0} ^ {m} {n \choose i}S(n,m)=∑i=0m ...
- 2019年杭电多校第三场 1008题Game(HDU6610+带修改莫队+Nim博弈)
题目链接 传送门 题意 给你\(n\)堆石子,每堆有\(a_i\)堆石子,\(q\)次操作: 在\([L,R]\)内有多少个子区间使得\(Alice\)(先手)在\(Nim\)博弈中获胜: 交换\(a ...
- 2019年牛客多校第三场 F题Planting Trees(单调队列)
题目链接 传送门 题意 给你一个\(n\times n\)的矩形,要你求出一个面积最大的矩形使得这个矩形内的最大值减最小值小于等于\(M\). 思路 单调队列滚动窗口. 比赛的时候我的想法是先枚举长度 ...
- [题解]Crazy Binary String-前缀和(2019牛客多校第三场B题)
题目链接:https://ac.nowcoder.com/acm/contest/883/B 题意: 给你一段长度为n,且只有 ‘0’ 和 ‘1’ 组成的字符串 a[0,...,n-1].求子串中 ‘ ...
- 启发式分治:2019牛客多校第三场 G题 Removing Stones
问题可以转换为求有多少个区间数字的总和除2向下取整大于等于最大值.或者解释为有多少个区间数字的总和大于等于最大值的两倍(但是若区间数字总和为奇数,需要算作减1) 启发式分治: 首先按最大值位置分治,遍 ...
随机推荐
- Python语言的循环语句、迭代器与生成器、函数学习
while循环语句 无限循环 我们可以通过设置条件表达式永远不为false来实现无限循环,实例如下: for语句 Python for循环可以遍历任何序列的项目,如一个列表或者一个字符串 Python ...
- 树莓派设置固定IP地址
vi /etc/dhcpcd.conf # 使用 vi 编辑文件,增加下列配置项 # 指定接口 eth0 interface eth0 # 指定静态IP,/24表示子网掩码为 255.255.255. ...
- CentOS:xmr-stak-cpu安装,服务器CPU挖Monero门罗币
一.获取钱包地址 可以使用本地钱包地址.首先到Monero官网下载本地钱包,支持Windows 64-bit.Windows 32-bit.Mac OS X 64-bit.Linux 64-bit.L ...
- Kafka(一)简介
1.Kafka简介 Kafka已经被很多公司广泛应用,一款实时流式消息组件.发送消息端称为Producer,接收端称为Consumer,Kafka集群有多个kafka实例组成,每个实例称为broker ...
- 在线制作微信跳转浏览器下载app/打开指定页面源码
微信自动跳转外部浏览器下载app/打开指定页面源码 源码说明: 适用安卓和苹果系统,支持任何网页链接.并且无论链接是否已经被微信拦截,均可实现微信内自动跳转浏览器打开. 生成的跳转链接具有极佳的防拦截 ...
- python2 线程基础
1,感谢菜鸟教程, 线程基础:导入,创建函数,创建线和运行 import thread import time # 为线程定义一个函数 def print_time(threadName, delay ...
- Depp Learning note Day1
1.softmax函数的优化来防止溢出 2.np.argmax()函数的使用 返回值为数组中最大值的索引 a = [1, 2, 3, 4, 3, 7] print(np.argmax(a)) 若np. ...
- 阻塞IO,非阻塞IO,IO多路复用模型
#服务端 import socket sk = socket.socket() sk.bind(('127.0.0.1',8080)) sk.listen() while True: conn, ad ...
- FTP、FTPS和SFTP
FTP 一.两种传输方式 ASCII传输方式 假定用户正在拷贝的文件包含的简单ASCII码文本,如果在远程机器上运行的不是UNIX,当文件传输时ftp通常会自动地调整文件的内容以便于把文件解释成另外那 ...
- 十个推荐使用的 Laravel 的辅助函数
壹. array_dot() array_dot () 辅助函数允许你将多维数组转换为使用点符号的一维数组. $array = [ 'user' => ['username' => 'so ...