n种珠宝。每种各1个。有价格ci元,美度vi。  要求分别输出1元到m元 可买的最大优美度。

整数 :0<n<=10000000, 0<ci<=300,0<=vi<=10^9, 0<m<=50000;

之前 系统的看过有关背包的题目。。然而这个做法还没见过。

首先复杂度是 300*m*log(m)+n

对1~300的每个价格 x, 按v从大到小排序,形成一个b数组。记录了价格为x的vi的前缀和(这里记为bj,   b[j]=b[j-1]+vi(当然。若j*x>m时 不用再继续记录。)

因为固定了当前只取价格为x的珍宝,所以,设f[i]为i元能买的最大价值  f[i]只能由f[i-t*u](t为自然数)更新而来。。 而b数组是上凸壳(①b是不减的,②因为对相同的价格,按vi从大到小排序。所以b的斜率是不增的。)

那么就可以用栈来做了:  设a[]为上一种价格x'计算完后 的f[],然后用a[]和b[]来更新f[]  ,那么f[i]=max(a[i-k*x]+b[i]), 换句话说,可以发现 每个a[i]可以在一段l~r上 作为max,且不会有另外的位置它会作max,同时i越大,对应的l,r也大。

  可以设 i%x=u  那么枚举u=0~x-1, 然后O(m/x)的扫一遍——for(i=u;i<=m;i+=x) , 用栈求出 每个a[i] 的l~r, 然后更新f[]。

细节多*意识模糊=一个晚上的颓废。。。。 上代码

 #include <cmath>
#include <cstdio>
#include <cctype>
#include <algorithm>
#define LL long long
using namespace std;
template<class T> inline void gn(T &x) {
char c; while(!isdigit(c=getchar())); x=c-'';
while(isdigit(c=getchar())) x=x*+c-'';
}
struct bla{
int c; LL v;
}o[];
int l,r,u,n,m,k,t,x,y,z,p,q,d[],e[];
LL b[],a[],f[];
inline bool cmp(bla a,bla b){if (a.c!=b.c) return a.c<b.c; return a.v>b.v;}
inline int get(int p,int q){
int L=(p-u)/x,R=(q-u)/x,l=R-,r=(m-u)/x,j;
while (l<r){
j=l+r+>>;
if(a[p]+b[j-L]>=a[q]+b[j-R]) l=j; else r=j-;
}
return u+l*x;
}
int main(){
freopen("jewelry.in","r",stdin);
freopen("jewelry.out","w",stdout);
gn(n); gn(m);
for (int i=;i<=n;++i) gn(o[i].c),gn(o[i].v);
sort(o+,o+n+,cmp);
for (int I=,J;I<=n;I=J){
x=o[I].c;
for (int i=;i<=k;++i) b[i]=; k=;
for (J=I;o[J].c==o[I].c;++J)
if (k*x+x<=m) b[++k]=b[k-]+o[J].v;
if (k*x>m) --k;
for (int i=;i<=m;++i) a[i]=f[i],f[i]=;
for (u=;u<x;++u){
t=;
for (int i=u;i<=m;i+=x){
while (t){
e[t]=get(d[t],i);
if (e[t]>e[t-]) break;
--t;
}
d[++t]=i;
}
e[t]=(m-u)/x*x+u;
for (int i=;i<=t;++i)
for (int j=e[i];j>e[i-];j-=x) f[j]=max(f[j],a[d[i]]+b[(j-d[i])/x]);
}
}
for (int i=;i<=m;++i){
f[i]=max(f[i],f[i-]);
printf("%I64d ",f[i]);
}
return ;
}

Sad

珠宝 jewelry 省选模拟的更多相关文章

  1. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  2. 省选模拟赛第四轮 B——O(n^4)->O(n^3)->O(n^2)

    一 稍微转化一下,就是找所有和原树差距不超过k的不同构树的个数 一个挺trick的想法是: 由于矩阵树定理的行列式的值是把邻接矩阵数值看做边权的图的所有生成树的边权乘积之和 那么如果把不存在于原树中的 ...

  3. NOI2019省选模拟赛 第五场

    爆炸了QAQ 传送门 \(A\) \(Mas\)的童年 这题我怎么感觉好像做过--我记得那个时候还因为没有取\(min\)结果\(100\to 0\)-- 因为是个异或我们肯定得按位考虑贡献了 把\( ...

  4. NOI2019省选模拟赛 第六场

    传送门 又炸了-- \(A\) 唐时月夜 不知道改了什么东西之后就\(A\)掉了\(.jpg\) 首先,题目保证"如果一片子水域曾经被操作过,那么在之后的施法中,这片子水域也一定会被操作&q ...

  5. 省选模拟赛 arg

    1 arg (arg.cpp/in/out, 1s, 512MB)1.1 Description给出一个长度为 m 的序列 A, 请你求出有多少种 1...n 的排列, 满足 A 是它的一个 LIS. ...

  6. 【NOI省选模拟】小奇的花园

    「题目背景」 小奇在家中的花园漫步时,总是会思考一些奇怪的问题. 「问题描述」 小奇的花园有n个温室,标号为1到n,温室以及以及温室间的双向道路形成一棵树. 每个温室都种植着一种花,随着季节的变换,温 ...

  7. [JZOJ6257] 【省选模拟8.9】修路

    题目 题目大意 有一堆点,每个点都有其权值\(c_i\). 每次插入边\((u,v)\),\(u\)和\(1\)连通,\(v\)和\(1\)不连通.最后保证形成一棵树. 每次插入的时候询问\(1\)到 ...

  8. @省选模拟赛03/16 - T3@ 超级树

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 一棵 k-超级树(k-SuperTree) 可按如下方法得到:取 ...

  9. 5.10 省选模拟赛 拍卖 博弈 dp

    LINK:拍卖 比赛的时候 前面时间浪费的有点多 写这道题的时候 没剩多少时间了. 随便设了一个状态 就开始做了. 果然需要认真的思考.其实 从我的状态的状态转移中可以看出所有的结论. 这里 就不再赘 ...

随机推荐

  1. bzoj1202:[HNOI2005]狡猾的商人 【并查集】

    Description 刁姹接到一个任务,为税务部门调查一位商人的账本,看看账本是不是伪造的.账本上记录了n个月以来的收入情况,其中第i 个月的收入额为Ai(i=1,2,3...n-1,n), .当 ...

  2. 【思维】2017多校训练七 HDU6121 Build a tree

    http://acm.hdu.edu.cn/showproblem.php?pid=6121 [题意] 询问n个结点的完全k叉树,所有子树结点个数的异或和是多少 [思路] 一棵完全K叉树,对于树的每一 ...

  3. openGL加载obj文件+绘制大脑表层+高亮染色

    绘制大脑表层并高亮染色的工作是以openGL加载obj文件为基础的,这里是我们用到的原始程序:只能加载一个obj文件的demo. 然而,一个完整的大脑表层是由很多分区组成的,因此我们的程序需要支持两个 ...

  4. C++,C程序设计入门——《高质量程序设计第4章》

    1. 连接规范 1. extern “C” 2. 一部分采用C的连接规范 #ifdef __cplusplus extern "C" { #endif #ifdef __cplus ...

  5. poj2112 二分+floyd+多源多汇最大流

    /*此题不错,大致题意:c头牛去k个机器处喝奶,每个喝奶处最多容纳M头牛,求所有牛中走的最长路的 那头牛,使该最长路最小.思路:最大最小问题,第一灵感:二分答案check之.对于使最长路最短, 用fo ...

  6. 纯Java Web项目下的Session共享方案收集(待实践)

    1.使用filter方法存储 这种方法比较推荐,因为它的服务器使用范围比较多,不仅限于tomcat ,而且实现的原理比较简单容易控制. 可以使用memcached-session-filter 官方网 ...

  7. simple-todo: 一个简易的 todo 程序 - django版

    今天无意间看到  simple-todo: 一个简易的 todo 程序 - web.py 中文教程 ,然后发现竟然有好多的版本 http://simple-is-better.com/news/tag ...

  8. Java入门 第一季第五章 编程练习解析

    这是我学习慕课网Java课程的笔记.原视频链接为:http://www.imooc.com/learn/85 5-1 基本写法 自己主动补全快捷键:alt + / 5-2 输入输出 使用Scanner ...

  9. C++卷积神经网络实例:tiny_cnn代码具体解释(6)——average_pooling_layer层结构类分析

    在之前的博文中我们着重分析了convolutional_layer类的代码结构.在这篇博文中分析相应的下採样层average_pooling_layer类: 一.下採样层的作用 下採样层的作用理论上来 ...

  10. activiti自己定义流程之自己定义表单(二):创建表单

    注:环境配置:activiti自己定义流程之自己定义表单(一):环境配置 在上一节自己定义表单环境搭建好以后,我就正式開始尝试自己创建表单,在后台的处理就比較常规,主要是针对ueditor插件的功能在 ...