codeforces 808 E. Selling Souvenirs (dp+二分+思维)
题目链接: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+二分+思维)的更多相关文章
- Codeforces 808 E. Selling Souvenirs(三分)
E. Selling Souvenirs 题意: n件物品,有重量和价值,重量只有三种1,2,3.问取不超过m重量的物品的价值总和最大是多少.(n<=1e5,w<=3e5) 思路: n*w ...
- Educational Codeforces Round 21E selling souvenirs (dp)
传送门 题意 给出n个体积为wi,价值为ci的物品,现在有一个m大的背包 问如何装使得最后背包内的物品价值最大,输出价值 分析 一般的思路是01背包,但n*v不可做 题解的思路 We can iter ...
- codeforces 808 D. Array Division(二分)
题目链接:http://codeforces.com/contest/808/problem/D 题意:有一串长度为n的数组,要求选择一个数字交换它的位置使得这串数能够分成两串连续的和一样的数组. 这 ...
- Codeforces Global Round 1D(DP,思维)
#include<bits/stdc++.h>using namespace std;int dp[1000007][7][7];int cnt[1000007];int main(){ ...
- Selling Souvenirs CodeForces - 808E (分类排序后DP+贪心)
E. Selling Souvenirs time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- [Codeforces 865C]Gotta Go Fast(期望dp+二分答案)
[Codeforces 865C]Gotta Go Fast(期望dp+二分答案) 题面 一个游戏一共有n个关卡,对于第i关,用a[i]时间通过的概率为p[i],用b[i]通过的时间为1-p[i],每 ...
- Codeforces C. Maximum Value(枚举二分)
题目描述: Maximum Value time limit per test 1 second memory limit per test 256 megabytes input standard ...
- HDU 3433 (DP + 二分) A Task Process
题意: 有n个员工,每个员工完成一件A任务和一件B任务的时间给出,问要完成x件A任务y件B任务所需的最短时间是多少 思路: DP + 二分我也是第一次见到,这个我只能说太难想了,根本想不到. dp[i ...
- 两种解法-树形dp+二分+单调队列(或RMQ)-hdu-4123-Bob’s Race
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4123 题目大意: 给一棵树,n个节点,每条边有个权值,从每个点i出发有个不经过自己走过的点的最远距离 ...
随机推荐
- NLP(十三)中文分词工具的使用尝试
本文将对三种中文分词工具进行使用尝试,这三种工具分别为哈工大的LTP,结巴分词以及北大的pkuseg. 首先我们先准备好环境,即需要安装三个模块:pyltp, jieba, pkuseg以及L ...
- 以太坊RLPx传输协议
本文主要内容翻译自:The RLPx Transport Protocol,其中添加了一些个人的理解,由于密码学水平有限,不正确之处望指正.另外原文可能已经更新,最新内容请直接阅读原文. 本文档定义了 ...
- 记录一下我做Udacity 的Data Scientist Nano Degree Project
做项目的时候看了别人的blog,决定自己也随手记录下在做项目中遇到的好的小知识点. 最近在做Udacity的Data Scientist Nano Degree Project的Customer_Se ...
- 一份新的lilypond谱子,能设置页边距和设置换页符了
给学生做的一份乐谱,这回能设置页边距了,以及设置换页符了. 顺带能设置一些代码片段(snippet),可以用热键代替使用 设置页边距的snippet: \paper { %双引号里面填页面大小 #(s ...
- javascript基础案例解析
学完了JavaScript基础部分,总结出一些基本案例,以备日后查看! 1.九九乘法口诀表:在控制台中输出九九乘法口诀表!代码如下: <!DOCTYPE html> <html> ...
- 阿里云短信服务(JAVA)
一,前言 短信验证码想必大家都不陌生,在很多网站,APP中都有使用到.比如登录,注册,身份校验等场景.不过通常情况下,短信服务都是外包给第三方公司的,接下来向大家分享如何使用阿里的短信服务. 二, ...
- Fabric项目学习总结
1.Hyperledger Fabric的基本架构 2.PKI机制
- 使用 .NET CORE 创建 项目模板,模板项目,Template
场景:日常工作中,你可能会碰到需要新建一个全新的解决方案的情况(如公司新起了一个新项目,需要有全新配套的后台程序),如果公司内部基础框架较多.解决方案需要DDD模式等,那么从新起项目到各种依赖引用到能 ...
- Golang 解决 Iris 被墙的依赖包
使用 Golang 的 Iris web 框架时,用 go get github.com/kataras/iris 命令久久无法下载,最后还报一堆错误. 使用 GOPROXY 可解决问题,也可参考如 ...
- 【win10主机】访问virtualbox上【32位winXP系统虚拟机】上启动的项目
win10上创建虚拟网卡: 1,右键此电脑点击管理——设备管理器——网络适配器: 2,点左上角菜单栏的 操作——添加过时硬件: 3,点下一步 4,点安装我手动从列表选择的硬件(高级)M 5,点网络适配 ...