购书打折
2016-06-03 17:56
183 查看
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。 设计算法能够计算出读者购买一批书的最低价格。
设计思路:
一批书价格最低 -> 一批书折扣最大 -> 平均每本书折扣最大
单本书最大折扣为25%(5本一套)
书数不能为5的整倍数时:
1~4本,按给定折扣享受最大优惠;
6~9本,经计算:
6本分成5+1本购买折扣最大;
7本分成5+2本购买折扣最大;
8本分成4+4本购买折扣最大;
9本分成5+4本购买折扣最大;
代码:
截图:
实验心得:……没证出为什么10本以上可以按10*n+m来算,感觉很失败。
本数 折扣
2 5%
3 10%
4 20%
5 25%
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。 设计算法能够计算出读者购买一批书的最低价格。
设计思路:
一批书价格最低 -> 一批书折扣最大 -> 平均每本书折扣最大
单本书最大折扣为25%(5本一套)
书数不能为5的整倍数时:
1~4本,按给定折扣享受最大优惠;
6~9本,经计算:
6本分成5+1本购买折扣最大;
7本分成5+2本购买折扣最大;
8本分成4+4本购买折扣最大;
9本分成5+4本购买折扣最大;
代码:
//2-5% 3-10% 4-20% 5-25% 6-(5+1) 7-(5+2) 8-(4+4) 9-(5+4) #include<iostream> using namespace std; int main() { int numbook=0; double summonny = 0; cout << "共买多少本书?" << endl << "本数:"; cin >> numbook; summonny += (numbook / 10 * 60); switch (numbook%10) { case 0:break; case 1:summonny += 8; break; case 2:summonny += 15.2; break; case 3:summonny += 21.6; break; case 4:summonny += 25.6; break; case 5:summonny += 30; break; case 6:summonny += 38; break; case 7:summonny += 45.2; break; case 8:summonny += 51.2; break; case 9:summonny += 55.6; break; default: break; } cout << "共" << summonny << "元。" << endl; return 0; }
截图:
实验心得:……没证出为什么10本以上可以按10*n+m来算,感觉很失败。
相关文章推荐
- CentOS下安装UNRAR
- django Error: [Errno 10013]怎么办
- HDU 1711 Number Sequence
- 自动备份MYSQL数据库删除五天前的旧档和上传到其他服务器
- Email之父去世:因他邮箱才有了@
- MongoVUE 1.6.9破解方法
- 60多年前,一群小白程序员扒了一个俄罗斯的开源框架
- 左图右文或者上图下文的排列
- Ubuntu配置samba实现文件夹共享
- ant 的详细的入门教程
- 关于RtlInitUnicodeString感想
- 关于PsCreateSystemThread函数
- css3 resize box-sizing outline-offset
- 查看正在执行的sql语句
- Ajax+Spring MVC实现跨域请求(JSONP)
- log4net写入mysql完整例子
- solrj
- Centos6.5下搭建Tomcat
- 监控指标模板的mini-textbox选择然后做级联操作,处罚相应的事件
- 产品可用性检验——启发式评估法十原则(尼尔森博士)