博客
关于我
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/

你可能感兴趣的文章
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>