BZOJ 3721: PA2014 Final Bazarek
3721: PA2014 Final Bazarek
Time Limit: 20 Sec Memory Limit: 128 MB
Submit: 645 Solved: 261
[Submit][Status][Discuss]
Description
有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 2 1 3
3
2
3
4
Sample Output
9
-1
HINT
Source
先对所有数字按照从大到小的顺序排序,然后维护前缀和,以及最小前缀(奇数/偶数),最大后缀(奇数/偶数)。
当询问K个的时候,如果sum[k]凑巧是个奇数,那么答案就是sum[k],否则就考虑用一个未添加的奇数换一个已添加的偶数,或是用一个未添加的偶数换一个已添加的奇数,二者取其大。
- #include <bits/stdc++.h>
- template <class T>
- inline void read(T &x) {
- char c = getchar(); x = ;
- while (c < '')
- c = getchar();
- while (c >= '') {
- x = x* + c - '';
- c = getchar();
- }
- }
- template <class T>
- inline T Max(const T &a, const T &b) {
- return a > b ? a : b;
- }
- template <class T>
- inline T Min(const T &a, const T &b) {
- return a < b ? a : b;
- }
- inline int cmp(const void *a, const void *b) {
- return - *(int *)a + *(int *)b;
- }
- typedef long long longint;
- const int inf = 2e9 + ;
- const int siz = ;
- int n, m;
- int num[siz];
- int min[siz][];
- int max[siz][];
- longint sum[siz];
- inline void prework(void) {
- qsort(num + , n, sizeof(int), cmp);
- memset(sum, , sizeof(sum));
- for (int i = ; i < siz; ++i)
- min[i][] = min[i][] = inf,
- max[i][] = max[i][] = -inf;
- for (int i = ; i <= n; ++i)
- sum[i] = sum[i - ] + num[i];
- for (int i = ; i <= n; ++i) {
- int a = num[i] & , b = a ^ ;
- min[i][a] = num[i];
- min[i][b] = min[i - ][b];
- }
- for (int i = n; i >= ; --i) {
- int a = num[i] & , b = a ^ ;
- max[i][a] = num[i];
- max[i][b] = max[i + ][b];
- }
- }
- inline bool judge(int k) {
- return
- (min[k][] == inf || max[k + ][] == -inf)
- && (min[k][] == inf || max[k + ][] == -inf);
- }
- inline void query(int k) {
- if (sum[k] & )
- printf("%lld\n", sum[k]);
- else if (judge(k))puts("-1");
- else printf("%lld\n",
- sum[k] + Max(
- - min[k][] + max[k + ][],
- - min[k][] + max[k + ][])
- );
- }
- signed main(void) {
- read(n);
- for (int i = ; i <= n; ++i)
- read(num[i]);
- prework();
- read(m);
- for (int i = , k; i <= m; ++i)
- read(k), query(k);
- }
@Author: YouSiki
BZOJ 3721: PA2014 Final Bazarek的更多相关文章
- BZOJ 3721: PA2014 Final Bazarek【乱搞】
有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价. Input 第一行一个整数n(1<=n<=1000000),表示商品数量.接下来一行有n个整数,表示每件商品的价格,范 ...
- 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 ...
- bzoj3721 [PA2014 Final] Bazarek
Description 有n件商品,选出其中的k个,要求它们的总价为奇数,求最大可能的总价. Input 第一行一个整数n(1<=n<=1000000),表示商品数量.接下来一行有n个整数 ...
- 【贪心】bzoj3721 PA2014 Final Bazarek
考虑不限制奇偶的情况,那就是直接排序取前k个的和. 加上奇偶限制:若排序后的前k个的和是偶数,则“显然地”:将其中的最小的奇数替换成未被选择的数中最大的偶数 或者 将其中的最小的偶数替换成未被选择的数 ...
- BZOJ 3727 PA2014 Final Zadanie 树形DP
题目大意:给定一棵树,令一个点到全部点的距离与点权的乘积之和为b[i].求每一个点的权值a[i] 首先假设给定a[i]我们能够非常轻松的求出b[i] 可是反过来怎么搞?高斯消元?30W? 考虑已知a[ ...
- BZOJ[3728]PA2014 Final Zarowki
有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮. 你可以去附近的商店换新灯泡,商店里所有正整数功率的灯泡都有售.但由于背包空间有 ...
- 【BZOJ-3721】Final Bazarek 贪心
3721: PA2014 Final Bazarek Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 610 Solved: 243[Submit][ ...
随机推荐
- BZOJ 2724: [Violet 6]蒲公英
2724: [Violet 6]蒲公英 Time Limit: 40 Sec Memory Limit: 512 MBSubmit: 1633 Solved: 563[Submit][Status ...
- C# Math类简介
Math.abs() 计算绝对值. Math.acos() 计算反余弦值. Math.asin() 计算反正弦值. Math.atan() 计算反正切值. Math.atan2() 计算从x 坐标轴到 ...
- springmvc请求参数异常处理
接着上一篇<springmvc 通过异常增强返回给客户端统一格式>讲通过spring ControllerAdvice对各种异常进行拦截处理,统一格式返回给客户端. 接下来我们更精细的讲, ...
- 让python在hadoop上跑起来
duang~好久没有更新博客啦,原因很简单,实习啦-好吧,我过来这边上班表示觉得自己简直弱爆了.第一周,配置环境:第二周,将数据可视化,包括学习了excel2013的一些高大上的技能,例如数据透视表和 ...
- 重建中国.NET生态系统
Neuzilla官方微信公众号:搜 架构师联盟 或 neuzilla 我是.NET铁杆粉丝,所以如果你要在评论里跟我撕逼.NET怎么怎么烂,Java.C++.PHP.JavaScript怎么怎么好,我 ...
- sprintf_s的教训
sprintf_s 是个比sprintf更安全的函数,今天在使用的过程中犯了个错误,代码的大致意思如下 void Test_sprintf_s() { ]; memset(buff, , sizeof ...
- spring+mybaties+springMvc+slf4j所需jar包
- C# Rotating Oval
This program is used to show how to generate an oval. The moon's orbit around the sun is an oval two ...
- git工作流程
git工作流程 一般工作流程如下: 克隆 Git 资源作为工作目录. 在克隆的资源上添加或修改文件. 如果其他人修改了,你可以更新资源. 在提交前查看修改. 提交修改. 在修改完成后,如果发现错误,可 ...
- tttttabs
<div id="fil-page" class="fil-page"> <div class="fil-container&quo ...