题目描述:

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. php单点登录

    http://blog.csdn.net/luyaran/article/details/54890036

  2. .net core 发送邮件

    var message = new MimeMessage();            //发送方            message.From.Add(new MailboxAddress(&qu ...

  3. 笨办法学python 文本复制

    本来面目 from sys import argv from os.path import exists script, from_file, to_file = argv print(f" ...

  4. Map、List、Set在Java中的各种遍历方法

    一.Map的4种遍历 Map<String, String> map = new HashMap<String, String>(); map.put("姓名&quo ...

  5. srping的历史与哲学

    历史: 要谈Spring的历史,就要先谈J2EE.J2EE应用程序的广泛实现是在1999年和2000年开始的,它的出现带来了诸如事务管理之类的核心中间层概念的标准化,但是在实践中并没有获得绝对的成功, ...

  6. Spring实现WebSocket通信

    WebSocket是两个应用之间全双工的通信通道.WebSocket最常见的应用场景是实现服务器和基于浏览器的应用之间的通信. 浏览器中的javascript客户端开启一个到服务器的连接,服务器通过这 ...

  7. 网页链接跳转qq聊天界面以及QQ群是什么实现的

    网页可以唤起QQ群,这我们都知道可以做到,那如何唤起呢?下面就做一个简单的介绍,希望可以帮助到有需要的朋友 1.官方提供的几种加群的链接 官方的加群代码的获取前提是我们具有权限(也就是群主或管理权限) ...

  8. Python_Mix*random模块,time模块,sys模块,os模块

    random模块 作用: 生成随机数(整数,小数,从列表中随机抽值,打乱列表顺序) 常用函数: random.random( )生成随机小数 random.uniform( )取一个范围之间的小数 r ...

  9. Forth 内部解释程序工作流程

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  10. 记录这段时间java编程的小知识点

    记录这段时间java编程的小知识点 eclipse项目导入中文乱码 eclipse左侧目录结构变动 eclipse代码段左右移动 按tal键,是整体右移. 按shift  table 同时按,是整体左 ...