题目链接:http://codeforces.com/contest/808/problem/E

题意:最多有100000个物品最大能放下300000的背包,每个物品都有权值和重量,为能够带的最大权值。

物品重量只有3中。重量为1,2,3。

题解:可以用3分写,这里先不介绍。主要讲一下二分+dp的方法。首先将重量为1,2,3的物品分别存下来,

然后从大到小排序一下。求一下前缀和,先将1,2二分,因为1,2的取法就两种要么取2,要么取两个1代替

2这里就需要二分,比较一下b[mid] and a[k-2*mid+1]+a[k-2*mid+2]的大小,b存的是2,a存的是1,

k表示背包放了多少,比较一下下一个应该是放2还是放两个1,由于原序列是排好序的,所以如果

b[mid]>a[k-2*mid+1]+a[k-2*mid+2]就可以往前二分,反正往后。最后用一个dp[i]表示放了i重量的背

包最大权值是多少。之后处理一下3就行了。

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long ll;
const int N = 3e5 + 10; int n, m, a[N], b[N], c[N], an, bn, cn;
ll sa[N], sb[N], sc[N], dp[N];
bool cmp(ll x , ll y) {return x > y;}
int main() {
scanf("%d %d", &n, &m);
for (int i = 1; i <= n; i ++) {
int w, x;
scanf("%d %d", &w, &x);
if (w == 1) a[++an] = x;
if (w == 2) b[++bn] = x;
if (w == 3) c[++cn] = x;
}
sort(a + 1, a + an + 1, cmp);
for (int i = 1; i <= m; i ++) sa[i] = sa[i-1] + a[i];
sort(b + 1, b + bn + 1, cmp);
for (int i = 1; i <= m; i ++) sb[i] = sb[i-1] + b[i];
sort(c + 1, c + cn + 1, cmp);
for (int i = 1; i <= m; i ++) sc[i] = sc[i-1] + c[i];
dp[1] = sa[1];
for (int k = 2; k <= m; k ++) {
if (sb[1] <= a[k] + a[k-1]) {
dp[k] = sa[k]; continue;
}
int l = 1, r = k / 2 + 1;
while (r > l + 1) {
int mid = (l + r) >> 1;
if (b[mid] > a[k-2*mid+1] + a[k-2*mid+2]) l = mid;
else r = mid;
}
dp[k] = sb[l] + sa[k-2*l];
}
for (int i = 1; i <= m; i ++) dp[i] = max(dp[i], dp[i-1]);
long long ans = 0;
for (int i = 0; i <= cn && i * 3 <= m; i ++) ans = max(ans, sc[i] + dp[m-3*i]);
printf("%lld\n", ans);
return 0;
}

codeforces 808 E. Selling Souvenirs (dp+二分+思维)的更多相关文章

  1. Codeforces 808 E. Selling Souvenirs(三分)

    E. Selling Souvenirs 题意: n件物品,有重量和价值,重量只有三种1,2,3.问取不超过m重量的物品的价值总和最大是多少.(n<=1e5,w<=3e5) 思路: n*w ...

  2. Educational Codeforces Round 21E selling souvenirs (dp)

    传送门 题意 给出n个体积为wi,价值为ci的物品,现在有一个m大的背包 问如何装使得最后背包内的物品价值最大,输出价值 分析 一般的思路是01背包,但n*v不可做 题解的思路 We can iter ...

  3. codeforces 808 D. Array Division(二分)

    题目链接:http://codeforces.com/contest/808/problem/D 题意:有一串长度为n的数组,要求选择一个数字交换它的位置使得这串数能够分成两串连续的和一样的数组. 这 ...

  4. Codeforces Global Round 1D(DP,思维)

    #include<bits/stdc++.h>using namespace std;int dp[1000007][7][7];int cnt[1000007];int main(){  ...

  5. Selling Souvenirs CodeForces - 808E (分类排序后DP+贪心)

    E. Selling Souvenirs time limit per test 2 seconds memory limit per test 256 megabytes input standar ...

  6. [Codeforces 865C]Gotta Go Fast(期望dp+二分答案)

    [Codeforces 865C]Gotta Go Fast(期望dp+二分答案) 题面 一个游戏一共有n个关卡,对于第i关,用a[i]时间通过的概率为p[i],用b[i]通过的时间为1-p[i],每 ...

  7. Codeforces C. Maximum Value(枚举二分)

    题目描述: Maximum Value time limit per test 1 second memory limit per test 256 megabytes input standard ...

  8. HDU 3433 (DP + 二分) A Task Process

    题意: 有n个员工,每个员工完成一件A任务和一件B任务的时间给出,问要完成x件A任务y件B任务所需的最短时间是多少 思路: DP + 二分我也是第一次见到,这个我只能说太难想了,根本想不到. dp[i ...

  9. 两种解法-树形dp+二分+单调队列(或RMQ)-hdu-4123-Bob’s Race

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4123 题目大意: 给一棵树,n个节点,每条边有个权值,从每个点i出发有个不经过自己走过的点的最远距离 ...

随机推荐

  1. 当面对会反制遭破解装置的App该如何顺利提取数据

    在检测App的过程之中,总会遇到比较棘手的,以”侦测是否遭破解的装置”为例,便会是个不好处理的状况.当App具备侦测装置是否已遭Root时,一旦发现装置已遭破解,便会停止运行,等于是只准安装及运行在未 ...

  2. java流压缩图片

    整理文档,搜刮出一个Java做图片压缩的代码,稍微整理精简一下做下分享.首先,要压缩的图片格式不能说动态图片,你可以使用bmp.png.gif等,至于压缩质量,可以通过BufferedImage来指定 ...

  3. 201312-2ISBN号码

    问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后一位 ...

  4. openjdk:8u22-jre-alpine在java开发中的NullPointerException错误解决方案

    问题描述 ** 在SpringBoot项目中使用了Ureport报表组件, 打包发布部署到docker中启动报错 ** java.lang.NullPointerException at sun.aw ...

  5. if IE语句 | 判断浏览器IE版本及添加升级提示

    本文引自:http://blog.csdn.net/u013372487/article/details/48521929 实现方法 判断当前浏览器是否IE6(或IE6内核) <!--[if I ...

  6. PowerShell安装IIS

    Windows作web开发的同学,应该都会用到IIS服务器.比如在阿里云或是Azure上购买一台新的服务器,默认是没有安装IIS的(安装的镜像就带有IIS或是MySql的除外).届时需要安装IIS,安 ...

  7. wwww

    public class MainActivity extends AppCompatActivity implements XListView.IXListViewListener{ ; priva ...

  8. ecshop 管理后台菜单及权限管理机制

    ecshop 所有的一级菜单选项存放于languages\zh_cn\admin\common.php 文件里面,使用 $_LANG['02_cat_and_goods'] = '商品管理';  这样 ...

  9. Python 面向導向語言 Object Oriented Programming Language

    Pytho 是面向對象的程式語言,舉凡 Literals 值都是 Object.例如: >>> id(38)8791423739696 與 >>> id('ABC' ...

  10. Shiro权限注解原理

    概述 前不久刚学会使用权限注解(),开始思索了一番.最开始猜测实现方式是注解@Aspect,具体实现方式类似如下所示(切面记录审计日志).后来发现并非如此,所以特地分析一下源码. @Component ...