【bzoj3312】[Usaco2013 Nov]No Change 状态压缩dp+二分
题目描述
Farmer John is at the market to purchase supplies for his farm. He has in his pocket K coins (1 <= K <= 16), each with value in the range 1..100,000,000. FJ would like to make a sequence of N purchases (1 <= N <= 100,000), where the ith purchase costs c(i) units of money (1 <= c(i) <= 10,000). As he makes this sequence of purchases, he can periodically stop and pay, with a single coin, for all the purchases made since his last payment (of course, the single coin he uses must be large enough to pay for all of these). Unfortunately, the vendors at the market are completely out of change, so whenever FJ uses a coin that is larger than the amount of money he owes, he sadly receives no changes in return! Please compute the maximum amount of money FJ can end up with after making his N purchases in sequence. Output -1 if it is impossible for FJ to make all of his purchases.
K个硬币,要买N个物品。
给定买的顺序,即按顺序必须是一路买过去,当选定买的东西物品序列后,付出钱后,货主是不会找零钱的。现希望买完所需要的东西后,留下的钱越多越好,如果不能完成购买任务,输出-1
输入
Line 1: Two integers, K and N.
* Lines 2..1+K: Each line contains the amount of money of one of FJ's coins.
* Lines 2+K..1+N+K: These N lines contain the costs of FJ's intended purchases.
输出
* Line 1: The maximum amount of money FJ can end up with, or -1 if FJ cannot complete all of his purchases.
样例输入
3 6
12
15
10
6
3
3
2
3
7
样例输出
12
题解
状压dp+二分
f[i]表示硬币使用状态为i时最多能购买的物品
那么有f[i]=k (sum[k]-sum[f[i^(1<<j)]]≤v[j])。
然后二分查找求出k即可。
还是注意数组从1开始的问题。
#include <cstdio>
#include <algorithm>
using namespace std;
int f[70000] , v[20] , a[100010] , sum[100010] , cost[70000] , n , base[70000];
int search(int z , int c)
{
int l = z , r = n , mid , ans = -1;
while(l <= r)
{
mid = (l + r) >> 1;
if(sum[mid] - sum[z] <= c)
ans = mid , l = mid + 1;
else r = mid - 1;
}
return ans;
}
int main()
{
int k , i , j , tmp , ans = -1 , sn = 0;
scanf("%d%d" , &k , &n);
for(i = 1 ; i <= k ; i ++ )
scanf("%d" , &v[i]) , sn += v[i] , base[1 << (i - 1)] = i;
for(i = 1 ; i <= n ; i ++ )
scanf("%d" , &a[i]) , sum[i] = sum[i - 1] + a[i];
for(i = 1 ; i < (1 << k) ; i ++ )
{
for(j = 1 ; j <= k ; j ++ )
{
if((1 << (j - 1)) & i)
{
tmp = search(f[i ^ (1 << (j - 1))] , v[j]);
if(tmp != -1)
f[i] = max(f[i] , tmp);
}
}
}
for(i = 1 ; i < (1 << k) ; i ++ )
{
cost[i] = cost[i - (i & (-i))] + v[base[i & (-i)]];
if(f[i] == n) ans = max(ans , sn - cost[i]);
}
printf("%d\n" , ans);
return 0;
}
【bzoj3312】[Usaco2013 Nov]No Change 状态压缩dp+二分的更多相关文章
- 【BZOJ3312】[Usaco2013 Nov]No Change 状压DP+二分
		[BZOJ3312][Usaco2013 Nov]No Change Description Farmer John is at the market to purchase supplies for ... 
- bzoj3312: [Usaco2013 Nov]No Change
		题意: K个硬币,要买N个物品.K<=16,N<=1e5 给定买的顺序,即按顺序必须是一路买过去,当选定买的东西物品序列后,付出钱后,货主是不会找零钱的.现希望买完所需要的东西后,留下的钱 ... 
- BFS+状态压缩DP+二分枚举+TSP
		http://acm.hdu.edu.cn/showproblem.php?pid=3681 Prison Break Time Limit: 5000/2000 MS (Java/Others) ... 
- 【bzoj3886】[Usaco2015 Jan]Moovie Mooving  状态压缩dp+二分
		题目描述 Bessie is out at the movies. Being mischievous as always, she has decided to hide from Farmer J ... 
- 【bzoj1231】[Usaco2008 Nov]mixup2 混乱的奶牛  状态压缩dp
		题目描述 混乱的奶牛[Don Piele, 2007]Farmer John的N(4 <= N <= 16)头奶牛中的每一头都有一个唯一的编号S_i (1 <= S_i <= ... 
- 【bzoj1725】[USACO2006 Nov]Corn Fields牧场的安排  状态压缩dp
		题目描述 Farmer John新买了一块长方形的牧场,这块牧场被划分成M列N行(1<=M<=12; 1<=N<=12),每一格都是一块正方形的土地.FJ打算在牧场上的某几格土 ... 
- bzoj 3312: [Usaco2013 Nov]No Change
		3312: [Usaco2013 Nov]No Change Description Farmer John is at the market to purchase supplies for his ... 
- hdu 4057 AC自己主动机+状态压缩dp
		http://acm.hdu.edu.cn/showproblem.php?pid=4057 Problem Description Dr. X is a biologist, who likes r ... 
- HOJ 2226&POJ2688 Cleaning Robot(BFS+TSP(状态压缩DP))
		Cleaning Robot Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4264 Accepted: 1713 Descri ... 
随机推荐
- 【commons】字符串工具类——commons-lang3之StringUtils
			类似工具见Hutool-StrUtil 一.起步 引入maven依赖 <!-- https://mvnrepository.com/artifact/org.apache.commons/com ... 
- TCP/IP漫游
			TCP/IP漫游 TCP/IP是互联网的基础协议栈,它包括大大小小几十个协议.本篇文章主要涉及到就是HTTP.TCP.IP协议.我们经常学的网络模型是七层或者五层,实际上一般认为一共只有四层就可以了. ... 
- core 中ef 连接sql server数据库  在类库中 自动生成 model
			首先 介绍 Scaffold-DbContext "Server=.;database=sdd;User Id=sa;Password=123456;" Microsoft.Ent ... 
- java操作HDFS
			package com.lei.hadoop; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.Fil ... 
- tcpdump使用
			1. tcpdump选项 它的命令格式为: tcpdump [ -DenNqvX ] [ -c count ] [ -F file ] [ -i interface ] [ -r file ][ -s ... 
- 网易七鱼 Android 高性能日志写入方案
			本文来自网易云社区 作者:网易七鱼 Android 开发团队 前言 网易七鱼作为一款企业级智能客服系统,对于系统稳定性要求很高,不过难保用户在使用中不会出现问题,而 Android SDK 安装在用户 ... 
- centos下php环境安装redis
			一.安装redis(仅可在服务器使用,尚不能通过浏览器访问) (1)首先下载redis:wget http://download.redis.io/releases/redis-4.0.9.tar.g ... 
- Java开发工程师(Web方向) - 04.Spring框架 - 第1章.Spring概述
			第1章.Spring概述 Spring概述 The Spring Framework is a lightweight solution and a potential one-stop-shop f ... 
- 【Python+OpenCV】人脸识别基于环境Windows+Python3 version_3(Anaconda3)+OpenCV3.4.3安装配置最新版安装配置教程
			注:本次安装因为我要安装的是win10(64bit)python3.7与OpenCV3.4.3教程(当下最新版,记录下时间2018-11-17),实际中这个教程的方法对于win10,32位又或是64位 ... 
- 一个五位数ABCDE乘以9,得到EDCBA,求此五位数
			此题是面试时某面试官突然抛出的,要求逻辑分析推导,不许编码,5分钟时间算出来最终结果,当然,最终没有完全推算出来 下面是编码实现 #一个五位数ABCDE*9=EDCBA,求此数 for a in ra ... 
