传送门:http://codeforces.com/contest/913/problem/C

n类物品,第i(i=0,1,2,...,n-1)类物品的价值为2i,花费为ci。任意选择物品,使得总价值至少为L。求此时的总花费的最小值。(n≤30,L≤109ci109

这是一个完全背包问题,但是鉴于数据规模,常规的DP是不可取的(TLE+MLE)。

首先考虑到的是递归地搜索答案。对于当前状态(cur,k),对价值cur做一个简单的划分:商q=cur/vi,余数r=cur%vi。商作为不可继续划分的部分计算花费:qcost=q*vi*ci,对余数继续搜索rcost,状态为(r,i)。对于当前状态,枚举i=k,k-1,...,0,找到最小的qcost+rcost,作为当前状态的返回值。这个做法一定可以得到正确的答案,但是,如此会TLE。

接下来考虑这个问题的数据是否可以优化。首先考虑c数组:

首先确定c数组的目标状态。这个目标状态应该满足约束:ci≤ci+12ci

ci+1≥ci:保证代价c的序列是上升的;

ci+12ci:保证性价比v/c的序列是上升的。

于是对于不满足约束的cici+1,则约束之。

ci=min(ci,ci+1);

ci+1=min(ci+1,2ci)。

完成c数组的约束之后,可以简单地求解这个问题了。

在约束后,由于代价序列是上升的,因此应从价值最小的物品开始考虑;

由于性价比序列是上升的,因此每一次花费,应获得价值尽可能高的物品。

于是考虑L的二进制位,设获得第0~i位的物品,对应的总花费为ans(i)。

则当第i位为0时,不获得物品i,价值0,花费0:ans(i)=ans(i-1);

当第i位为1时,获得物品i,价值vi,花费cians(i)=ans(i-1)+ci

有一个例外的情况:当获得更高位的物品i+1所花费的ci+1≤ans(i)时,丢弃0~i位的所有物品,转而获得物品i+1:ans(i)=ci+1

于是从低位到高位遍历即可。参考程序如下:

#include <stdio.h>
#include <stdint.h>
#define MAX_N 31 const int64_t inf = (int64_t)1e18;
int64_t c[MAX_N], v[MAX_N];
int64_t minc[MAX_N]; int64_t min(int64_t a, int64_t b)
{
return a < b? a: b;
} int main(void)
{
int n, l;
scanf("%d%d", &n, &l);
for (int i = ; i < n; i++) {
scanf("%d", &c[i]);
if (i) c[i] = min(c[i], 2LL * c[i - ]);
if (i) c[i - ] = min(c[i - ], c[i]);
v[i] = << i;
}
for (int i = n; i < MAX_N; i++)
c[i] = 2LL * c[i - ];
int64_t ans = 0LL;
for (int i = ; i < MAX_N - ; i++) {
int p = << i;
if (l & p) ans += c[i];
ans = min(ans, c[i + ]);
}
printf("%I64d\n", ans);
return ;
}

Codeforces Hello 2018 C - Party Lemonade的更多相关文章

  1. Codeforces Goodbye 2018

    Goodbye 2018 可能是我太菜考试的时候出不了$E$ 可能是我太菜考试的时候调不出$F$ 所以转化为手速场之后手速还上不去.jpg A 模拟题意... #include <cstdio& ...

  2. Codeforces Hello 2018 E题Logical Expression dp+最短路 好题

    j题目链接: http://codeforces.com/contest/913/problem/E 题意: 给你x,y,z三个变量,与&   或|  非!  括号()   四种运算符,规定括 ...

  3. 【CodeForces】913 C. Party Lemonade

    [题目]C. Party Lemonade [题意]给定n个物品,第i个物品重量为2^(i-1)价值为ci,每个物品可以无限取,求取总重量>=L的最小代价.1<=30<=n,1< ...

  4. Codeforces - Gym102028 - 2018 Jiaozuo Regional Contest

    http://codeforces.com/gym/102028 A. Xu Xiake in Henan Province 看起来像水题.乱搞一下,还真是. #include<bits/std ...

  5. Week Five

    2018.12.25 1.[BZOJ 4310] 2.[BZOJ 3879] 3.[BZOJ 2754] 4.[BZOJ 4698] 5.[Codeforces 914E] 6.[Codeforces ...

  6. Codeforces Avito Code Challenge 2018 D. Bookshelves

    Codeforces Avito Code Challenge 2018 D. Bookshelves 题目连接: http://codeforces.com/contest/981/problem/ ...

  7. Codeforces 1023 A.Single Wildcard Pattern Matching-匹配字符 (Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Fi)

    Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Final) A. Single Wildcard Patter ...

  8. Codeforces:Good Bye 2018(题解)

    Good Bye 2018! 题目链接:https://codeforces.com/contest/1091 A. New Year and the Christmas Ornament 题意: 给 ...

  9. Codeforces Round #434 (Div. 2, based on Technocup 2018 Elimination Round 1)&&Codeforces 861C Did you mean...【字符串枚举,暴力】

    C. Did you mean... time limit per test:1 second memory limit per test:256 megabytes input:standard i ...

随机推荐

  1. YTU 2798: 复仇者联盟之数组成绩统计

    2798: 复仇者联盟之数组成绩统计 时间限制: 1 Sec  内存限制: 128 MB 提交: 136  解决: 96 题目描述 定义一个5行3列的二维数组,各行分别代表一名学生的高数.英语.C++ ...

  2. 【POJ 2559】 Largest Rectangle in a Histogram

    [题目链接] http://poj.org/problem?id=2559 [算法] 单调栈 [代码] #include <algorithm> #include <bitset&g ...

  3. Poj2054 color a tree && [HNOI/AHOI2018]排列

    https://zybuluo.com/ysner/note/1120723 题面 原题 某省选强化题 大致意思是给你一颗树,选父亲后才能选儿子. 每个点对答案的贡献为你在第几次选这个点 × 该点权值 ...

  4. npm 与 package.json 快速入门教程

    npm 与 package.json 快速入门教程 2017年08月02日 19:16:20 阅读数:33887 npm 是前端开发广泛使用的包管理工具,之前使用 Weex 时看了阮一峰前辈的文章了解 ...

  5. Behavior Designer扩展

    BehaviorManager.instance.Tick(behaviorTree); 卸载update里u3d直接卡死 = = SharedVariable直接赋值会改变他的引用关系,必须用XXX ...

  6. 微信小程序之上传多张图片

    之前写过一篇小程序商品发布的博客,里面有上传多张图片的功能,这里单独拿出来实现以下,小程序的upLoadFile一次只能上传一张图片,需要循环调这个接口来实现 for (var i = 0; i &l ...

  7. 【知识总结】多项式全家桶(二)(ln和exp)

    上一篇:[知识总结]多项式全家桶(一)(NTT.加减乘除和求逆) 一.对数函数\(\ln(A)\) 求一个多项式\(B(x)\),满足\(B(x)=\ln(A(x))\). 这里需要一些最基本的微积分 ...

  8. OI——不后悔的两年

    NOI2014,悲惨的考跪,99+170+130 399 Cu滚粗.最终签到了复旦的一本,还算是有点结果吧.(其实我一开始就想读复旦我会说?)回首这两年,就像一场梦一样,从一无所知的小白到进入省队再到 ...

  9. xcode常用的快捷键

    按键 描述 command+[ 左移代码块 command+] 右移代码块 Tab键 接受代码自动完成提示 Esc键 显示代码提示菜单 command+方向left键 移动光标到本行行首 comman ...

  10. 笔记《精通css》第3章 盒模型,定位,浮动,清理

    第3章    盒模型,定位,浮动,清理 1.盒模型用到的属性width,height,padding,border,margin 普通文档流的上下垂直margin会叠加 2.块级框 与 行内框, 利用 ...