编程之美 1.4买书问题常数时间空间解法
在 节假日的时候,书店一般都会做促销活动。由于《哈利波特》系列相当畅销,店长决定通过促销活动来回馈读者。在销售的《哈利波特》平装本系列中,一共有五 卷,用编号0, 1, 2, 3, 4来表示。假设每一卷单独销售均需要8欧元。如果读者一次购买不同的两卷,就可以扣除5%的费用,三卷则更多。假设具体折扣的情况如下:
分析:
首先假设五册书分别为A,B,C,D,E,不失一般性可以假设Na>=Nb>=Nc>=Nd>=Ne
设所有书可以划分为k组,每组中书不重复,
则在最优解中有如下性质:
1 所有只包含一本书的组均只包含同一本书
若有两组包含一本书的组包含的书不同,则这两组合并,能得到更优解,与最优解矛盾.
2包含一本书的组只包含A
若包含书为A',若Na'==Na,则A,A'对调即可
若Na'<Na,则必存在某组包含A不包含A',则将只包含A'的组并入该组能得到更优解
3所有只包含两本书的组均包含相同两本书
组(A', B'), (A',C')折扣0.2重组为(A',B',C')与(A)折扣0.3
4包含两本书的组必包含A
若存在包含一本A的组,而两本书的组不包含A,则合并能得更优解
若不存在包含一本A的组,而两本书组包含为A',A'',则包含三本书,四本组必含A而缺A'者
(A', A''), (AXY), 折扣0.4不如(A''),(AXYA')0.8
(A',A''),(AXYZ)折扣0.9不如(A''),(AXYZA')1.25
5 包含两本书的组必包含B
同上证
6所有只包含三本书的组均包含相同三本书
(A,B,C),(A,B,D)折扣0.6,(A,B),(A,B,C,D)折扣0.9
7所有包含三本书的组均包含A
若存在只包含A的组,合并得更优
若存在只包含A, B的组(A,B)(XYZ)折扣0.4,不如(B)(AXYZ)折扣0.8
若不存在一,二本组,假设三本书组为(X,Y,Z),则必有包含A的四本组缺X,(X,Y,Z)(A,A',A'',A''')折扣1.1,不如
(Y,Z),(A,A',A'',A''',X)折扣1.35
8所有包含三本的组均包含B,C
同上可证
9所有包含四本书的组均包含A,B,C
设XYZW为
(ABC)(BCDE)折扣1.1,不如(B,C),(A,B,C,D,E)折扣1.35
其它情况同理可证
10包含五本书与包含三本书情况不会同时出现
(A,B,C),(A,B,C,D,E)折扣1.55,不如(A,B,C,D),(A,B,C,E)折扣1.6
由以上证明可得如下结论
- 每组均包含A,所有组数与A相同
- 所有包含两本及以上的组均包含B,组数与B同
- 所有包含三本及以上的组均包含C,组数与C同
- 三,五不并存
由此可得解法如下:

const double BuyBook::DISCOUNTS[5] = {1, 0.95, 0.9, 0.8, 0.75};
static const int BOOK_KINDS = 5;
double BuyBook::SearchFast(int* books)
{
Sort(books);
int g[5];
g[0] = books[0] - books[1];
g[1] = books[1] - books[2];
g[2] = books[2] - books[3];
g[3] = books[3] - books[4];
g[4] = books[4];
int t = min(g[2], g[4]);
if (t > 0)
{
g[2] -= t;
g[4] -= t;
g[3] += 2 * t;
}
double sum = 0;
for (int i = 0; i < BOOK_KINDS; ++i)
{
sum += g[i] * (i+1) * UNIT_PRICE * DISCOUNTS[i];
}
return sum;
}
posted on 2011-02-05 17:22 Michael Peng 阅读(2249) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库