Description

http://www.lydsy.com/JudgeOnline/upload/Noi2017D2.pdf

Solution

网上大部分都是并查集写法,但是有大神写了非并查集写法,特别容易理解

首先 \(s_i\) 的限制,只需将每一个蔬菜分出一个价值为 \(a_i+s_i\) 且过期时间为该蔬菜最晚的一天的蔬菜

把时间倒序之后,问题转化为每个蔬菜会在第几天出现,每天贪心选择价值最大的即可

先求出 \(\max \{p_i \}\) 的答案,然后递推 \([1,\max \{pi\}-1]\) 的答案:每次删除价值最小的 \(m\) 单位蔬菜,不难发现所有蔬菜的销售时间依然合法

#include<bits/stdc++.h>
#define ui unsigned int
#define ll long long
#define db double
#define ld long double
#define ull unsigned long long
const int MAXN=100000+10,P=100000;
int n,m,k,a[MAXN],c[MAXN],x[MAXN],s[MAXN],vis[MAXN];
ll ans[MAXN],sale[MAXN],tot;
struct node{
ll id,val;
inline bool operator < (const node &A) const {
return val<A.val;
};
inline bool operator > (const node &A) const {
return val>A.val;
};
};
std::vector<int> V[MAXN];
std::queue<node> red;
std::priority_queue<node> q1;
std::priority_queue< node,std::vector<node>,std::greater<node> > q2;
template<typename T> inline void read(T &x)
{
T data=0,w=1;
char ch=0;
while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
if(ch=='-')w=-1,ch=getchar();
while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
x=data*w;
}
template<typename T> inline void write(T x,char ch='\0')
{
if(x<0)putchar('-'),x=-x;
if(x>9)write(x/10);
putchar(x%10+'0');
if(ch!='\0')putchar(ch);
}
template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
template<typename T> inline T min(T x,T y){return x<y?x:y;}
template<typename T> inline T max(T x,T y){return x>y?x:y;}
int main()
{
read(n);read(m);read(k);
for(register int i=1;i<=n;++i)
{
read(a[i]),read(s[i]),read(c[i]),read(x[i]);
if(x[i]==0)V[P].push_back(i);
else V[min(P,(c[i]+x[i]-1)/x[i])].push_back(i);
}
for(register int i=P;i>=1;--i)
{
for(register int j=0,lt=V[i].size();j<lt;++j)q1.push({V[i][j],a[V[i][j]]+s[V[i][j]]});
ll rest=m;
while(!q1.empty()&&rest)
{
node now=q1.top();
q1.pop();
if(vis[now.id])
{
ll res=min(rest,c[now.id]-(i-1)*x[now.id]-sale[now.id]);
ans[P]+=1ll*res*a[now.id];sale[now.id]+=res;rest-=res;
if(sale[now.id]<c[now.id])red.push(now);
}
else
{
vis[now.id]=1;
ans[P]+=now.val;sale[now.id]++;rest--;
if(sale[now.id]<c[now.id])q1.push((node){now.id,a[now.id]});
}
}
while(!red.empty())q1.push(red.front()),red.pop();
}
for(register int i=1;i<=n;tot+=sale[i],++i)
if(sale[i]==1)q2.push((node){i,a[i]+s[i]});
else if(sale[i])q2.push((node){i,a[i]});
for(register int i=P-1;i>=1;--i)
{
ans[i]=ans[i+1];
ll rest=tot-1ll*m*i;
if(rest<=0)continue;
else
while(!q2.empty()&&rest)
{
node now=q2.top();
q2.pop();
if(sale[now.id]==1)sale[now.id]--,rest--,ans[i]-=now.val;
else
{
int res=min(rest,sale[now.id]-1);
sale[now.id]-=res,rest-=res,ans[i]-=1ll*res*now.val;
if(sale[now.id]==1)q2.push((node){now.id,a[now.id]+s[now.id]});
else if(sale[now.id])q2.push((node){now.id,a[now.id]});
}
}
tot=1ll*m*i;
}
for(register int i=1,x;i<=k;++i)read(x),write(ans[x],'\n');
return 0;
}

【刷题】BZOJ 4946 [Noi2017]蔬菜的更多相关文章

  1. BZOJ.4946.[NOI2017]蔬菜(贪心 离线)

    题目链接 因为有删除,考虑倒序处理某个p的询问. 那么每天删除xi的蔬菜就变成了每天运来xi的蔬菜.那么我们取当前最优的即可,早取晚取都一样,不需要留给后面取,还能给后面更优的留出空间. 这样就只需考 ...

  2. 4946: [Noi2017]蔬菜

    4946: [Noi2017]蔬菜 http://www.lydsy.com/JudgeOnline/upload/Noi2017D2.pdf 分析: 贪心. 首先可以将一个蔬菜拆成两个,一个是有加成 ...

  3. [NOI2017]蔬菜 贪心

    题面: [NOI2017]蔬菜 题解: 首先每天蔬菜会变质这点并不好处理,我们考虑让时间倒流,从后向前处理,这样的话就相当于每天都会得到一定量的蔬菜. 这样做有什么好处呢? 我们可以发现一个性质:如果 ...

  4. 【刷题】BZOJ 2407 探险

    Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作人员说明了这次比赛的规则: ...

  5. 【刷题】BZOJ 4543 [POI2014]Hotel加强版

    Description 同OJ3522 数据范围:n<=100000 Solution dp的设计见[刷题]BZOJ 3522 [Poi2014]Hotel 然后发现dp的第二维与深度有关,于是 ...

  6. 【刷题】BZOJ 4316 小C的独立集

    Description 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. 这不,小C让小D去求一个无向图的最大独立集,通俗地讲就是:在无向图中选出若干个点,这些点互相没有边连接,并使 ...

  7. 【刷题】BZOJ 4176 Lucas的数论

    Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目"求Sigma(f(i)),其中1<=i< ...

  8. BZOJ第一页刷题计划

    BZOJ第一页刷题计划 已完成:67 / 90 [BZOJ1000]A+B Problem:A+B: [BZOJ1001][BeiJing2006]狼抓兔子:最小割: [BZOJ1002][FJOI2 ...

  9. 【刷题】BZOJ 2260 商店购物

    Description Grant是一个个体户老板,他经营的小店因为其丰富的优惠方案深受附近居民的青睐,生意红火.小店的优惠方案十分简单有趣.Grant规定:在一次消费过程中,如果您在本店购买了精制油 ...

随机推荐

  1. jqgrid 点击列头的超链接或按钮时,不触发列排序事件

    接上篇文章:jqgrid 将列头设置为超链接或按钮 如果在列头设置了超链接或按钮,在点击超链接或按钮时会触发列的排序事件. 原由:点击超链接/按钮会触发排序的冒泡事件 解决方法:点击超链接/按钮时,阻 ...

  2. VBA删除 语法

    Option Explicit '清空数据  Private Sub CommandButton1_Click() Dim qknum As Integer  '选择是或者否 来确认删除数据 '中对话 ...

  3. ASP.NET Core2.1 你不得不了解的GDPR(Cookie处理) - (转载)

    前言 时间一晃 ASP.NET Core已经迭代到2.1版本了. 迫不及待的的下载了最新的版本,然后生成了一个模版项目来试试水. ...然后就碰到问题了... 我发现..cookie竟然存不进去了.. ...

  4. springboot 定制错误页面

    项目中经常遇到的异常情况 400-Bad Request 401-Unauthorized If the request already included Authorization credenti ...

  5. Vivado中xilinx_courdic IP核(求exp指数函数)使用

    由于Verilog/Vhdl没有计算exp指数函数的库函数,所以在开发过程中可利用cordic IP核做exp函数即e^x值: 但前提要保证输入范围在(-pi/4—pi/4) 在cordic核中e^x ...

  6. flask之jinjia2模板(二)

    1.1.模板传参 (1)主程序 from flask import Flask,render_template app = Flask(__name__) @app.route('/') def he ...

  7. C#_IO操作

    1.创建文件夹 //using System.IO; Directory.CreateDirectory(%%1);   2.创建文件 //using System.IO; File.Create(% ...

  8. Jenkins Maven安装设置

    Jenkins Maven安装设置 如果没有学习过 Maven 的朋友,可以先了解 Maven教程,然后再进一步学习本教程文章. 第1步:下载和设置Maven Maven的官方网站就是Apache M ...

  9. 一篇带你读懂TCP之“滑动窗口”协议

    前言 你现在的努力,是为了以后有更多的选择. 在上一篇文章通过"表白"方式,让我们快速了解网络七层协议了解了网络七层协议. 接下来我们要把重心放在网络传输的可靠性上面.一起来看TC ...

  10. (第十二周)新功能WBS

    项目名:食物链教学工具 组名:奋斗吧兄弟 组长:黄兴 组员:李俞寰.杜桥.栾骄阳.王东涵 新增加的功能:背景音乐 功能 子功能 二级子功能 预计花费时间(小时) 实际花费时间(小时) 背景音乐 界面组 ...