BZOJ 3721: PA2014 Final Bazarek【乱搞】
有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价。
Input
第一行一个整数n(1<=n<=1000000),表示商品数量。
接下来一行有n个整数,表示每件商品的价格,范围在[1,10^9]。
接下来一行有一个整数m(1<=m<=1000000),表示询问数量。
接下来m行,每行一个整数k[i](1<=k[i]<=n)。
Output
对于每个询问,输出一行表示保证奇数的情况下最大的总价。若无法满足要求,输出-1。
Sample Input
4
4 2 1 3
3
2
3
4
Sample Output
7
9
-1
思路:如果不要是奇数,那么..........排个序 输出前K个。。。。。。。。。。。。。
如果前K个已经是奇数的话直接输出即可
如果不是呢?
思考熊。。。
果断猜了个命题:设第K大的数为X,将X替换成不在前K大的和X奇偶性不一样的最大的数,这样一定是最优的。
仔细思考了后发现这个命题不够完善 例如下面这个数据:
5
2 99 101 102 133
1000
1
2
3
唔 K=3时用上面那个算法做出来的是133+102+2 但最优的是133+101+99
于是完善了上面的算法:设在前K大的数中与X奇偶性相同的最小的数为Y(如果存在的话),那么把Y当成X替换成不在前K大中的奇偶性与Y不同的最大的那个数 这样算出的数和上面算法一算出的数取个最大值就是答案了
然后YY了个证明:设Bi表示i个数不在前k大数中的K个数的和的最大值,则Bi>=B(i+1),即i+1个数不在前K大里的答案绝对不优于i个数不在前K大里的答案
因此优先考虑0个数不在前K大里 即就是前K大的和 如果不为奇数,那么考虑只有1个数不在前K大里,显然通过以上方法一定能将和调整为奇数,或者题目无解。
接下来考虑为何用以上算法是调整一个数时的最大值:显然由于此时前K大的和为偶数,因此调整一个数要么把奇数调整成一个偶数,要么把偶数调整成一个奇数,那显然就是将最小的偶数调整成最大的奇数 或者最小的奇数调整成最大的偶数就可以了
//bzoj2464
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <iostream>
#define maxn 1000009
using namespace std;
int a[maxn],foredif[maxn],same[maxn],badif[maxn];
long long sum[maxn];
int cmp(int x, int y){return x>y;}
long long mmax(long long x,long long y)
{
return x>y?x:y;
}
int main()
{
long long n,k,lasto=-1,laste=-1,m;
scanf("%lld",&n);
for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
sort(a+1,a+1+n,cmp);
for(int i=1;i<=n;i++)sum[i]=sum[i-1]+a[i];
for(int i=1;i<=n;i++)
{
if((a[i]&1)==1)//odd
{
foredif[i]=laste;
lasto=i;
}
else
{
foredif[i]=lasto;
laste=i;
}
}
lasto=laste=-1;
for(int i=n;i>=1;i--)
{
if((a[i]&1)==1)//odd
{
same[i]=lasto;
badif[i]=laste;
lasto=i;
}
else
{
same[i]=laste;
badif[i]=lasto;
laste=i;
}
}
scanf("%lld",&m);
for(int i=1;i<=m;i++)
{
scanf("%lld",&k);
long long s=sum[k];
if((s&1)==1){printf("%lld\n",s);continue;}
if(badif[k]==-1)
{
if(same[k]==-1||foredif[k]==-1)s=-1;else
s=(long long)s+(long long)a[same[k]]-(long long)a[foredif[k]];
}
else
{
if(same[k]==-1||foredif[k]==-1)s=s-(long long)a[k]+(long long)a[badif[k]];
else
{
s=mmax((long long)s+(long long)a[same[k]]-(long long)a[foredif[k]],(long long)s-(long long)a[k]+(long long)a[badif[k]]);
}
}
printf("%lld\n",s);
}
return 0;
}
BZOJ 3721: PA2014 Final Bazarek【乱搞】的更多相关文章
- BZOJ 3721: PA2014 Final Bazarek
3721: PA2014 Final Bazarek Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 645 Solved: 261[Submit][ ...
- bzoj 3721: PA2014 Final Bazarek 贪心
如果没有限制,直接取前 $k$ 大即可. 有限制,则只有几种可能:奇换偶,偶换奇. 维护奇数偶数的前缀最小值和后缀最大值即可. code: #include <bits/stdc++.h> ...
- 【BZOJ3721】PA2014 Final Bazarek 贪心
[BZOJ3721]PA2014 Final Bazarek Description 有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价. Input 第一行一个整数n(1<=n ...
- bzoj 3722: PA2014 Final Budowa
3722: PA2014 Final Budowa Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 303 Solved: 108[Submit][St ...
- BZOJ 3727 PA2014 Final Zadanie 树形DP
题目大意:给定一棵树,令一个点到全部点的距离与点权的乘积之和为b[i].求每一个点的权值a[i] 首先假设给定a[i]我们能够非常轻松的求出b[i] 可是反过来怎么搞?高斯消元?30W? 考虑已知a[ ...
- bzoj3721 [PA2014 Final] Bazarek
Description 有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价. Input 第一行一个整数n(1<=n<=1000000),表示商品数量.接下来一行有n个整数 ...
- 【BZOJ】2456 mode(乱搞)
Description 给你一个n个数的数列,其中某个数出现了超过n div 2次即众数,请你找出那个数. Input 第1行一个正整数n.第2行n个正整数用空格隔开. Output 一行一个正整数表 ...
- bzoj 4900 [CTSC2017]密钥 模拟+乱搞
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4900 #include<cstring> #include<cmath&g ...
- 【贪心】bzoj3721 PA2014 Final Bazarek
考虑不限制奇偶的情况,那就是直接排序取前k个的和. 加上奇偶限制:若排序后的前k个的和是偶数,则“显然地”:将其中的最小的奇数替换成未被选择的数中最大的偶数 或者 将其中的最小的偶数替换成未被选择的数 ...
随机推荐
- MySQL防止重复插入记录SQL
INSERT INTO sysuser(') DUAL:表示虚拟表 sysuser:表名称
- 使用gitblit 在windows平台搭建git服务器
1.下载jdk,安装并且配置好环境变量 2.下载gitblit 直接解压无需安装 3.配置gitblit 1.修改gitblit安装目录下的data文件下的gitblit.properties.将in ...
- 11.1Java-接口
一.接口 interface定义:固定格式 public abstract 返回值类型 方法名字(参数列表);代码: public interface AMyInterface { public ab ...
- canvas画饼图
<style> body { background: black; text-align: center; } #cans { background: white; } ...
- Deprecated: Assigning the return value of new by reference is deprecated in报错
出现了Deprecated: Assigning the return value of new by reference is deprecated in wwwroot\common.inc.ph ...
- Oracle EXPDP and IMPDP
一.特点 • 可通过 DBMS_DATAPUMP 调用 • 可提供以下工具: – expdp – impdp – 基于 Web 的界面 • 提供四种数据移动方法: – 数据文件复制 – 直接路径 – ...
- 在SAP UI中使用纯JavaScript显示产品主数据的3D模型视图
在Jerry写这篇文章时,通过Google才知道,SAP其实是有自己的3D模型视图显示解决方案的. 故事要从Right Hemisphere说起,这是一家专业的企业级2D/3D模型浏览及转换的软件供应 ...
- Oracle的Central Inventory和Local inventory详解
很多朋友对Oracle的inventory信息不太了解以至遇到相关的问题不知道如何处理,这篇文章我们将详细讲解Oracle的Central Inventory (oraInventory)和Local ...
- Python 基础语法学习(第一讲)---类的使用
[写在前面]:其实自学python有一段时间了,但是一直没想起来要写博客来记录自己的学习,今天才感觉要写点什么让自己学的更扎实一点,所以从今天开始更新python自学系列,希望看见文章的大佬们可以指点 ...
- springcloud 之 bus 消息总线
在分布式系统中,我们通常使用轻量级消息代理(rabbitmq.kafuka)建立一个公共的主题,让所有的微服务都链接进来,并且监听消费这个主题的内容,我们就称这个主题是 消息总线. (可以用作配置文件 ...