题目描述:

Neko has a loop of size n.
The loop has a happy value ai on the i−th(0≤i≤n−1) grid. 
Neko likes to jump on the loop.She can start at anywhere. If she stands at i−th grid, she will get ai happy value, and she can spend one unit energy to go to ((i+k)modn)−th grid. If she has already visited this grid, she can get happy value again. Neko can choose jump to next grid if she has energy or end at anywhere. 
Neko has m unit energies and she wants to achieve at least s happy value.
How much happy value does she need at least before she jumps so that she can get at least s happy value? Please note that the happy value which neko has is a non-negative number initially, but it can become negative number when jumping

输入:

The first line contains only one integer T(T≤50), which indicates the number of test cases. 
For each test case, the first line contains four integers n,s,m,k(1≤n≤104,1≤s≤1018,1≤m≤109,1≤k≤n).
The next line contains n integers, the i−th integer is ai−1(−109≤ai−1≤109)

该题关键在于:一个环,环上每点有一个权值,可以从任意点开始走,问至多走m步情况下所经过点的权值和最大是多少。主要比较难想的在于O(nlogn)地求一个环上至多长为k的字段和的最大值。

主要思路:可以在扫一遍的过程中一个个地求以i为结尾的至多长为k的字段和的最大值。维护一个单调队列,保证队头一直是点{i-k..i-k+1....i-i}的前缀和中的最小值,i的前缀和减去该最小值即为i为结尾的至多长为k的字段和的最大值。

单调队列的维护:1.若队头的时间戳与i距离大于k,则队头出队。2.每次将i的前缀和入队的时候,循环进行操作:队尾若大于i的前缀和则队尾出队。

#include<bits/stdc++.h>
#define rep(i,a,b) for(long long i=a;i<=b;++i)
using namespace std;
long long n,m,s,k;
const long long MAXN=1e4+;
long long a[MAXN];
void Input()
{
scanf("%lld%lld%lld%lld",&n,&s,&m,&k);
rep(i,,n-) scanf("%lld",a+i);
}
long long gcd(long long a,long long b)
{
return b==?a:gcd(b,a%b);
}
long long ring[MAXN];
long long head;
long long vis[MAXN];
long long pre[MAXN];
void init()
{
memset(vis,,sizeof(vis));
}
int tail=;
struct Qu
{
long long t,val;
Qu() {}
Qu(long long _val,long long _t)
{
t=_t;
val=_val;
}
}q[*MAXN];
void update(long long idx)
{
Qu one(pre[idx],idx+);
while(tail>=head)
{
if(q[tail].val>=one.val) tail--;
else break;
}
q[++tail]=one;
}
void debug2(long long i)
{
printf("i:%lld\n",i);
rep(i,head,tail)
{
printf("val:%lld t:%lld\n",q[i].val,q[i].t);
}
}
long long calc(long long lim,long long len)
{
// printf("lim:%lld\n",lim);
long long presum=;
rep(i,len,*len-) ring[i]=ring[i-len];
rep(i,,*len-)
{
presum+=ring[i];
pre[i]=presum;
// printf("%lld ",pre[i]);
}
head=;
tail=;
long long maxans=;
q[head]=Qu(,);
rep(i,,*len-)
{
update(i); int nowlen=(i+)-q[head].t;
if(nowlen>lim)
{
head++;
}
// debug2(i); //printf("maxans:%lld val:%lld\n",maxans,pre[i]-q[head].val);
maxans=max(maxans,pre[i]-q[head].val);
}
return maxans; }
void debug(long long len)
{
rep(i,,len-) printf("%d ",ring[i]);
printf("\n");
}
void work(long long icase)
{
long long num=gcd(n,k);
long long ans=;
rep(i,,n-)
{
if(vis[i]) continue;
head=;
long long sum=;
long long len=;
for(long long j=i;!vis[j];j=(j+k)%n)
{
// printf("j:%lld\n",j);
ring[head++]=a[j];
sum+=a[j];
len++;
vis[j]=;
}
long long time=m/len;
long long maxseq;
if(sum<)
{
sum=;
maxseq=calc(min(len - , m), len);
}
else maxseq=calc(m%len,len);
// debug(len);
long long other=calc(len-,len);
if(m>=len)
{
if (other > sum + maxseq){
long long res = (time-) * sum;
long long ians = res + other;
ans = max(ians,ans);
}else{
long long res=time*sum;
long long ians=res+maxseq;
ans=max(ians,ans);
}
}else{
long long res=time*sum;
long long ians=res+maxseq;
ans=max(ians,ans);
}
}
long long finalans=s-ans;
if(finalans<) finalans=;
printf("Case #%lld: %lld\n",icase,finalans);
}
int main()
{
long long T;
scanf("%lld",&T);
rep(tt,,T)
{
init();
Input();
work(tt);
}
return ;
}

2018 CCPC网络赛 hdu6444 Neko's loop的更多相关文章

  1. 2018 CCPC网络赛

    2018 CCPC网络赛 Buy and Resell 题目描述:有一种物品,在\(n\)个地点的价格为\(a_i\),现在一次经过这\(n\)个地点,在每个地点可以买一个这样的物品,也可以卖出一个物 ...

  2. HDU 6444 Neko's loop ( 2018 CCPC 网络赛 && 裴蜀定理 && 线段树 )

    题目链接 题意 : 给出一个 n 个元素的环.可以任意选择起点.选完起点后.可以行走 m 步.每次前进 k 个单位.所走到的点将产生正或负贡献.问你一开始得准备多少才能使得初始资金加上在环上获取最大利 ...

  3. 2018 CCPC网络赛 几道数学题

    1002 Congruence equation 题目链接  : http://acm.hdu.edu.cn/showproblem.php?pid=6439 题解 : https://www.zyb ...

  4. 2018 CCPC 网络赛 Buy and Resell

    The Power Cube is used as a stash of Exotic Power. There are n cities numbered 1,2,…,n where allowed ...

  5. 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...

  6. 【2018 CCPC网络赛 1004】Find Integer(勾股数+费马大定理)

    Problem Description people in USSS love math very much, and there is a famous math problem . give yo ...

  7. 【2018 CCPC网络赛】1001 - 优先队列&贪心

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6438 获得最大的利润,将元素依次入栈,期中只要碰到比队顶元素大的,就吧队顶元素卖出去,答案加上他们期中 ...

  8. 【2018 CCPC网络赛】1009 - 树

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6446 题目给出的数据为一棵树,dfs扫描每条边,假设去掉某条边,则左边 x 个点,右边 n-x 个点, ...

  9. 【2018 CCPC网络赛】1003 - 费马小定理

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6440 这题主要是理解题意: 题意:定义一个加法和乘法,使得 (m+n)p = mp+np; 其中给定 ...

随机推荐

  1. 和初学者交流学习java语言一些体会。

    对初学者,自己学习java语言的一些体会: 1.工欲善其事,必先利其器.先把Java学习工具准备好,包括集成开发环境IDE,自己觉得MyEclipse比较适合,还有数据库,Oracle或MySQL,S ...

  2. 学习PYTHON之路, DAY 9 - Socket网络编程

    __import__ 两种方法,官方推荐下面的方法 Socket 参数介绍 sk.bind(address) 必会 s.bind(address) 将套接字绑定到地址.address地址的格式取决于地 ...

  3. 用HTML+CSS编写一个计科院网站首页的静态网页

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. Surface RT2使用情况

    Surface RT2是一个6年的古董了,暂时还能使用的功能包括但不限于一些xbox小游戏,ppt阅读(加载慢),pdf阅读(加载慢),word阅读. 2018/6/16 爱奇艺关闭了大部分win8R ...

  5. 微信小程序 遇到的问题(新)

    1.调用wx.chooseImage(),调用系统相册,此时相册中的动图被转化成静态图,上传后也是静态图. 2.刚进微信小程序,onShow在安卓机下会调用两遍,iPhone下正常

  6. springboot解决文件上传大小限制

    (1)在配置文件(application.properties)加入如下代码 springboot2.0以下配置为: spring.http.multipart.maxFileSize = 10Mb ...

  7. 关于Phabricator Arcanist以及提交项目代码

    git配置 github的使用:https://github.com/runchen0518/OnlineJudge/blob/master/README.md $ git config --glob ...

  8. 随机函数rand()与srand()

    一.int rand(void); 函数所在的头文件是stdlib.h: 其内部实现线性同除法,不是真正的随机数.通常rand()%x是指在x范围内取模,返回值0-x; 系统默认随机种子是1: 二.v ...

  9. js 统计字符串中字符出现的次数

    var str='abbcccdddd';var obj={};for(var i=0;i<str.length;i++){ var key=str.charAt(i); if(obj[key] ...

  10. 20145338 《网络对抗》 MSF基础应用

    20145338<网络对抗> MSF基础应用 实验内容 ·掌握metasploit的基本应用方式,掌握常用的三种攻击方式的思路. 具体需要完成(1)一个主动攻击;(2)一个针对浏览器的攻击 ...