购买促销书籍的问题
2016-05-31 10:24
218 查看
题目
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元,具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
1 根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
2 设计算法能够计算出读者购买一批书的最低价格。
3 要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。
设计思想
根据折扣和买书数量可以知道:当买书量大于10本时,将数量进行求余,算出当买6、7、8、9本书时的最小价格,其余能够被5整除的直接用买5套的折扣价即为最优方案。
源代码
程序截图
实验总结
这次实验的主要面临的问题就是购买6-9本书和购买11-14本书是否进行%5求余的问题,解决了这个问题就基本可以写出复杂程度较低的算法来了
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元,具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
1 根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
2 设计算法能够计算出读者购买一批书的最低价格。
3 要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。
设计思想
根据折扣和买书数量可以知道:当买书量大于10本时,将数量进行求余,算出当买6、7、8、9本书时的最小价格,其余能够被5整除的直接用买5套的折扣价即为最优方案。
源代码
#include<iostream> using namespace std; float priceLowest; void f(int bookNum) { int N; N=bookNum%5; switch(N) { case 0: priceLowest=bookNum*8*0.75; break; case 1: priceLowest=(bookNum-N)*8*0.75+8; break; case 2: priceLowest=(bookNum-N)*8*0.75+2*8*0.95; break; case 3: priceLowest=(bookNum-N)*8*0.75+4*8*0.8*2-5*8*0.75; if(bookNum<5) { priceLowest+=0.4; } break; case 4: priceLowest=(bookNum-N)*8*0.75+4*8*0.8; break; default: cout<<"Error!"<<endl; } } void main() { int q=0; while(q==0) { int bookNum; cout<<"请输入购买数量:"; cin>>bookNum; f(bookNum); cout<<"最低价格为:"<<priceLowest<<endl; cout<<"是否继续测试?(输入0继续)"; cin>>q; } }
程序截图
实验总结
这次实验的主要面临的问题就是购买6-9本书和购买11-14本书是否进行%5求余的问题,解决了这个问题就基本可以写出复杂程度较低的算法来了
相关文章推荐
- IntelliJ IDEA 使用说明(For Eclipse user)
- Maven与Ant的区别
- CodeForces 672A Summer Camp
- Redis Cluster学习笔记
- openedx环境部署-fullstatck
- iOS开发:UITableView加载多张照片导致内存上涨的问题
- JS中&&和||用法
- tomcat7和tomcat8 对 资源路径的解析
- javascript实现简易计算器的代码
- Oracle SQL日期比较
- 零散知识点
- 为什么Redis内存不宜过大
- 排序算法之快速排序
- poj 3177 双连通分量+缩点
- 使用Gitblit 在windows 上部署你的Git Server
- React Native Android错误总结
- gradle配置
- GDB使用小结- 可带参数
- Spring中配置数据源的4种形式
- Scala简明教程(1)