题目链接

\(Description\)

有k种饮料,浓度Ai给出,求用最少的体积配成n/1000浓度的饮料。

\(Solution\)

根据题意有方程 (A1x1+A2x2+...+Anxn)/[(x1+x2+...+xn)1000] = x/1000

xi表示Ai选多少升(0<=xi).1000可以约掉.

这样带着带着选与不选不好考虑(我为什么会这么考虑。。太naive了)

ai表示选了ai浓度1L,则(a1+a2+...+am) = m*n

那么 ∑(ai-n) = 0 , -1000 <= ai-n <= 1000

于是1.可以以0为起点BFS,把每个(ai-n)作为一条边,直到(用最少的步数)再走到0

或是2.考虑DP,用f[i][sum]表示用iL是否得到sum

于是朴素的DP:

for(i=1; i<=1000; ++i)//可以证明最多只需要1000L
for(sum=-1000; sum<=1000; ++sum)//需要对sum加个偏移量
for(j=1; j<=k; ++j)
if(-1000<=sum-(a[j]-n)<=1000)
f[i][sum]|=f[i-1][sum-(a[j]-n)]

这仍然是O(n^3)的

可以把sum的一层循环用bitset压掉(f[i-1]左移a[j]位后再右移n位)。这个复杂度?O((n^3)/64)?

上面的证明(最多需要1kL): 假设要配x浓度,有a>x的浓度、b<x的浓度,有u(a-x)+v(b-x)=0

u=x-b, v=a-x时,就可以配成x,此时u+v = a-b <= 1000

ai只需考虑1000以内的即可

//31ms	5744KB
//被卡T了。。不得不加个特判
#include <cstdio>
#include <cctype>
#include <bitset>
#define gc() getchar()
const int N=1e6+5; int n,k,cnt,A[N];
bool vis[1005];
std::bitset<2018> f[2]; inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
} int main()
{
n=read(),k=read();
for(int tmp,i=1; i<=k; ++i)
if((tmp=read())<=1000) A[++cnt]=tmp,vis[tmp]=1;
f[1][1000]=1;
if(cnt<1000)
for(int now=1,las,i=1; i<=1000; ++i)
{
las=now, now^=1;
f[now].reset();
for(int j=1; j<=cnt; ++j)
f[now]|=(f[las]<<A[j])>>n;
if(f[now][1000]) {printf("%d",i); return 0;}
}
else
for(int now=1,las,i=1; i<=1000; ++i)
{
las=now, now^=1;
f[now].reset();
for(int j=0; j<=1000; ++j)
if(vis[j]) f[now]|=(f[las]<<j)>>n;
if(f[now][1000]) {printf("%d",i); return 0;}
}
printf("-1"); return 0;
}

Codeforces.788C.The Great Mixing(bitset DP / BFS)的更多相关文章

  1. Codeforces 788C The Great Mixing

    The Great Mixing 化简一下公式后发现, 问题变成了, 取最少多少数能使其和为1, bitset优化一下背包就好啦. 题解中介绍了一种bfs的方法没, 感觉比较巧妙. #include& ...

  2. Codeforces 788C The Great Mixing(背包问题建模+bitset优化或BFS)

    [题目链接] http://codeforces.com/problemset/problem/788/C [题目大意] 给出一些浓度的饮料,要求调出n/1000浓度的饮料,问最少需要多少升饮料 [题 ...

  3. Codeforces 789e The Great Mixing (bitset dp 数学)

    Sasha and Kolya decided to get drunk with Coke, again. This time they have k types of Coke. i-th typ ...

  4. hdu 3247 AC自动+状压dp+bfs处理

    Resource Archiver Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 100000/100000 K (Java/Ot ...

  5. Codeforces 755F PolandBall and Gifts bitset + 二进制优化多重背包

    PolandBall and Gifts 转换成置换群后, 对于最大值我们很好处理. 对于最小值, 只跟若干个圈能否刚好组能 k 有关. 最直观的想法就是bitset优化背包, 直接搞肯定T掉. 我们 ...

  6. 洛谷P3724 大佬 [AH2017/HNOI2017] dp+bfs

    正解:dp+bfs 解题报告: 传送门! 这题看起来很复杂的样子其实真的很复杂 但是仔细看一下题目,会发现其实操作只有两个目的嘛,一个是保证自己不死,一个是让对手减血 而且保证自己不死只有一种操作 而 ...

  7. BZOJ_3049_[Usaco2013 Jan]Island Travels _状压DP+BFS

    BZOJ_3049_[Usaco2013 Jan]Island Travels _状压DP+BFS Description Farmer John has taken the cows to a va ...

  8. BZOJ_1415_[Noi2005]聪聪和可可_概率DP+bfs

    BZOJ_1415_[Noi2005]聪聪和可可_概率DP+bfs Description Input 数据的第1行为两个整数N和E,以空格分隔,分别表示森林中的景点数和连接相邻景点的路的条数. 第2 ...

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

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

随机推荐

  1. 【逆向工具】IDA使用4-控制台逆向分析 Reverse004.exe 获取密码

    工具 吾爱破解版本OD.IDA6.8 OD使用-动态分析 OD快捷方式 F2 下断点,也就是指定断点的地址F3加载一个可执行程序,进行调试分析F4程序执行到光标处 F5 缩小.还原当前窗口 F7 单步 ...

  2. sublime3 python 缩进问题

    注意,在sublime中可以选择使用空格还是tap进行缩进, 可以宰这里面进行选择: 如果选择了使用tap符进行缩进,再用空格进行缩进,就会报undinent(没有缩进的错误),也可以这样判断,如果有 ...

  3. kafka系列九、kafka事务原理、事务API和使用场景

    一.事务场景 最简单的需求是producer发的多条消息组成一个事务这些消息需要对consumer同时可见或者同时不可见 . producer可能会给多个topic,多个partition发消息,这些 ...

  4. 【转】snprintf()函数使用方法

    众所周知,sprintf不能检查目标字符串的长度,可能造成众多安全问题,所以都会推荐使用snprintf. 注:sprintf()函数:int sprintf( char *buffer, const ...

  5. activiti报错ProcessEngines.getDefaultProcessEngine()为null

    activiti报错ProcessEngines.getDefaultProcessEngine()为null 文件名错误,默认加载classpath下面的activiti.cfg.xml,而不是ac ...

  6. Go语言规格说明书 之 内建函数(Built-in functions)

    go version go1.11 windows/amd64 本文为阅读Go语言中文官网的规则说明书(https://golang.google.cn/ref/spec)而做的笔记,介绍Go语言的 ...

  7. == 和 equal 区别

    在初学 Java 时,可能会经常碰到下面的代码: String str1 = new String("hello"); String str2 = new String(" ...

  8. LeetCode(59):螺旋矩阵 II

    Medium! 题目描述: 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, ...

  9. LeetCode(8):字符串转整数(atoi)

    Medium! 题目描述: 实现 atoi,将字符串转为整数. 在找到第一个非空字符之前,需要移除掉字符串中的空格字符.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合 ...

  10. python 全栈开发,Day60(MySQL的前戏,数据库概述,MySQL安装和基本管理,初识MySQL语句)

    一.MySQL的前戏 在学习Mysql之前,我们先来想一下一开始做的登录注册案例,当时我们把用户的信息保存到一个文件中: #用户名 |密码 root|123321 alex|123123 上面文件内容 ...