博客
关于我
Codeforces Round #616 (Div. 2) C - Mind Control(暴力枚举)
阅读量:387 次
发布时间:2019-03-05

本文共 691 字,大约阅读时间需要 2 分钟。

在这里插入图片描述

在这里插入图片描述
题意:给定初始序列,规定每次操作只能拿序列的头元素和尾元素,,而你是第m个拿的,你可以控制任意k个人的选择,问在你控制了k个人的选择后,不论剩下m-1-k个人不管怎么选,我最后选的数字都会大于一个数X,求X的最大值。
思路:一开始以为是贪心,结果疯狂wa,最后还是在别人的灵感下使用了暴力。。。如果有用贪心过此题的大佬也请教教我这个菜鸡QAQ。。。
我们选枚举我们控制的人(范围是0到k),再枚举我们没控制的人(范围是0到m-k-1),假设现在轮到我拿了(也就是到了m时刻),而此时我们控制的人在头部拿了i个数字,不受我们控制的人拿了j个数字,那么在队尾我们控制的人拿了几个元素呢?答案是k-i个(仔细想想是不是?),不受我们控制的人在队尾拿了拿了n–(m-k-1-j)-(k-i)个元素,这样的话我能拿到首尾元素是不是分别是a[i+j],a[n-1-(m-1-k-j)-(k-i)](注意一下我这里的数组下标是从0开始的,所以边界要自己控制好),然后这两个取max是不是就是我拿的数了,然后对这个结果取最小值(也就是X),然后再取最大值就是答案了。

#include
using namespace std;typedef long long ll;const int maxn=3e3+1;const int inf=1e9+10;int T,n,m,k,a[maxn],ans,res;int main(){ scanf("%d",&T); while(T--) { scanf("%d%d%d",&n,&m,&k); for(int i=0;i

转载地址:http://raewz.baihongyu.com/

你可能感兴趣的文章
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>