[USACO13NOV]没有找零No Change [TPLY]
[USACO13NOV]没有找零No Change
题目链接 https://www.luogu.org/problemnew/show/3092
做题背景
FJ不是一个合格的消费者,不知法懂法用法,不会拿起法律的武器维护消费者权益
做法
本题涉及的知识点:状态压缩,动态规划,二分答案。
注意物品是依次购买
首先是状态压缩:
压什么?我们注意到k<=16,那么就是压硬币使用集合。
然后是动态规划:
怎么设状态?设dp[i]表示我们选硬币集合i(状压)从一号物品开始最多能买的物品数。
怎么转移?从0开始枚举每一个可能的硬币集合i(状压)
找到每一个存在于使用集合i中的硬币
(例如在集合11001中1,2,5是存在于集合i中的)
然后从不包含该硬币的集合中转移过来
(即11001从01001,10001,11000中转移过来)
再是二分答案:哪里需要二分答案?在转移过程中.我们需要找到利用硬币最多能买到的物品数,枚举太耗时间,前缀和二分答案就可以加快速度了。
几点注意:
转移开long long
位运算优先级有点头疼,能打括号打括号
Ans设为-1,不能设为0因为可能存在正好一点不剩的最优解
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#include <queue>
#define RG register
#define rg register int
#define rc register char
#define ll long long
#define il inline
#define INF 2147483647
#define SZ 100001
using namespace std;
il int gi()
{
rg x=0,o=0;rc ch=getchar();
while(ch!='-'&&(ch<'0'||'9'<ch))ch=getchar();
if(ch=='-') o=1,ch=getchar();
while('0'<=ch&&ch<='9') x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
return o?-x:x;
}
int k,n;
ll tot,Ans,a[SZ],sum[SZ],dp[65537],c[17];
// 查询一个数二进制中1的个数
il ll num(rg x)
{
RG ll cnt=0;
for(rg i=0;i<k;++i)
if((x>>i)&1)
cnt+=c[i+1];
return cnt;
}
//手写upperbound函数
il int Upper(ll *array,int size,ll key)
{
rg hd=1,len=size;
while(len>0)
{
rg mid=hd+(len>>1);
if(array[mid]>key) len>>=1;
else hd=mid+1,len=len-(len>>1)-1;
}
return hd;
}
// upper_bound
int main()
{
k=gi(),n=gi();
for(rg i=1;i<=k;++i) c[i]=gi(),tot+=c[i];
for(rg i=1;i<=n;++i) a[i]=gi(),sum[i]=sum[i-1]+a[i];
for(rg i=0;i<=(1<<k)-1;++i)
for(rg j=0;j<k;++j)
if((i>>j)&1)
{
ll tmp=(i^(1<<j));
tmp=Upper(sum,n,sum[dp[tmp]]+c[j+1]);
dp[i]=max(dp[i],tmp-1);
}
Ans=-1;
for(rg i=0;i<=(1<<k)-1;++i)
if(dp[i]==n)
Ans=max(Ans,tot-num(i));
printf("%lld",Ans);
return 0;
}
[USACO13NOV]没有找零No Change [TPLY]的更多相关文章
- 洛谷P3092 [USACO13NOV]没有找零No Change
P3092 [USACO13NOV]没有找零No Change 题目描述 Farmer John is at the market to purchase supplies for his farm. ...
- P3092 [USACO13NOV]没有找零No Change
题目描述 Farmer John is at the market to purchase supplies for his farm. He has in his pocket K coins (1 ...
- 洛谷 P3092 [USACO13NOV]没有找零No Change
题目描述 Farmer John is at the market to purchase supplies for his farm. He has in his pocket K coins (1 ...
- luogu P3092 [USACO13NOV]没有找零No Change
题目描述 Farmer John is at the market to purchase supplies for his farm. He has in his pocket K coins (1 ...
- P3092 [USACO13NOV]没有找零No Change 状压dp
这个题有点意思,其实不是特别难,但是不太好想...中间用二分找最大的可买长度就行了. 题干: 题目描述 Farmer John <= K <= ), each with value .., ...
- Luogu P3092 [USACO13NOV]没有找零No Change【状压/二分】By cellur925
题目传送门 可能是我退役/NOIP前做的最后一道状压... 题目大意:给你\(k\)个硬币,FJ想按顺序买\(n\)个物品,但是不能找零,问你最后最多剩下多少钱. 注意到\(k<=16\),提示 ...
- 【[USACO13NOV]没有找零No Change】
其实我是点单调队列的标签进来的,之后看着题就懵逼了 于是就去题解里一翻,发现楼上楼下的题解说的都好有道理, f[j]表示一个再使用一个硬币就能到达i的某个之前状态,b[now]表示使用那个能使状态j变 ...
- [luoguP3092] [USACO13NOV]没有找零No Change(状压DP + 二分)
传送门 先通过二分预处理出来,每个硬币在每个商品处最多能往后买多少个商品 直接状压DP即可 f[i]就为,所有比状态i少一个硬币j的状态所能达到的最远距离,在加上硬币j在当前位置所能达到的距离,所有的 ...
- [洛谷P3092]【[USACO13NOV]没有找零No Change】
状压\(DP\) + 二分 考虑构成:\(k<=16\)所以根据\(k\)构造状压\(dp\),将所有硬币的使用情况进行状态压缩 考虑状态:数组\(dp[i]\)表示用\(i\)状态下的硬币可以 ...
随机推荐
- 简述java中equals()方法和==的区别
==与equals的主要区别是: ==: ==常用于比较原生类型(基本数据类型):byte,short,char,int,long,float,double,boolean,比较的是他们的值. 若用= ...
- typedef void(*Fun)(void);
typedef void(*Fun)(void); 函数类似于数组,函数名就是它的首地址: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 ...
- yum出问题啦
BUG 不小心把/usr/local上的一堆文件(夹)给删除了,于是乎,一堆问题冒出来了 loading mirror speeds from cached hostfile 解决方法 一定要执行 y ...
- Java String使用总结
1 == 与 equals() 使用==来比较两个primitive主数据类型在意义上相等(是否带有相同的字节组合),或者判断两个引用(如String变量)是否引用同一个对象.使用equals()来判 ...
- Mysql查询某字段值重复的数据
查询user表中,user_name字段值重复的数据及重复次数 select user_name,count(*) as count from user group by user_name havi ...
- 【JavaWeb】DbUtils入门之QueryRunner
DbUtils简介 根据官网的介绍,DbUtils是一种 JDBC Utility Component (翻译过来大概就是:JDBC实用部件),故名思意,和数据库操作有关 官网上的简介也称之为 JDB ...
- Mac下使用SSH(密钥)访问Github
1,终端中输入:cd ~/.ssh 如果出现 -bash: cd: /Users/glamor/.ssh: No such file or directory,说明你之前没有用过.直接执行第二步. 如 ...
- PHP的性能优化方法总结
什么情况之下,会遇到PHP性能问题? 1:PHP语法使用不恰当. 2:使用PHP语言做了它不擅长的事情. 3:使用PHP语言连接的服务不给力. 4:PHP自身的短板(PHP自身做不了的事情). 5:我 ...
- TP3.2 中使用 PHPMailer 发送邮件
第一步.添加PHPMailer类库 http://pan.baidu.com/s/1o7Zc7V0 第二步.添加发送邮件函数 在common目录中的公共函数文件加入函数 <?php /***** ...
- 老男孩Python全栈开发(92天全)视频教程 自学笔记18
day18课程内容: os模块 import osprint(os.getcwd())#D:\untitled\练习题 获取当前工作目录os.chdir(r'D:\untitled\练习题\16.1切 ...