2022国赛 蓝桥杯C++ C组 Python B组 I.打折

本文详细解析了一道关于物品购买的算法题,利用贪心策略和平衡树数据结构来优化解决方案。在每个时间点,选择当前最低价格的物品购买,用平衡树维护每个物品在不同时间的价格,并通过树状数组更新最小价格。算法复杂度为O(n log n),实现了高效求解。
摘要由CSDN通过智能技术生成

 

 

题解:1.贪心:最后选择的时间点一定为某一个物品的打折开始时间点。因为如果我们选择的时间点,不是任何一个时间的打折点那么我们可以让这个时间前移答案至少不会变坏。

2.每一个物品在当前可以购买的价格可以用一棵平衡树维护,表示在当前时间点每个物品的可以选择的价格集合。

3.考虑时间点的右移,我们只需要记录当前物品 i 原来的价格为 p 现在价格为 q,那么只需要在平衡树 i 中删除一个 p 价格并插入一个 q 价格即可。

4.因为所以物品都需要买一个所以根据贪心我们在每棵平衡树中都要选择最小值。我们使用一棵树状数组维护即可。即每次平衡树变化时我们先记录这颗平衡树的最小值在与修改后的最小值进行比较如果发生了变化就修改树状数组。

具体来说,对于读入物品 s_i~t_i~p_i~c_i 我们处理出点 s_i c_i w_i 以及点 t_i+1~w_i~c_i 其中 w_i 表示打折后的价格。任何按第一关键字即时间排序表示所有的修改操作。然后将所以的 c_i 插入对应的multiset即可。

复杂度分析:修改最多为2*\sum c_i 记为 k 则复杂度为 k*log(k) .

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值