购买图书问题
2016-06-02 23:47
295 查看
一、题目:
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
设计算法能够计算出读者购买一批书的最低价格。
要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。
二、设计思想:
通过分析这道题目,找出规律为求余问题,我们可以先求出5,6,7,8,9四组的最佳方案,其余的数据mod5再加5,又是5,6,7,8,9这几种情况,就可以得出最佳方案了。
三、代码:
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
设计算法能够计算出读者购买一批书的最低价格。
要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。
二、设计思想:
通过分析这道题目,找出规律为求余问题,我们可以先求出5,6,7,8,9四组的最佳方案,其余的数据mod5再加5,又是5,6,7,8,9这几种情况,就可以得出最佳方案了。
三、代码:
#include "stdio.h" int main() { int bnum,num,num1,jixu; double money; a1: printf("请输入书的数量:"); scanf("%d",&bnum); num1=bnum/5-1; num=bnum%5+5; switch(num) { case 5: money=5*8*0.75; break; case 6: money=5*8*0.75+8; break; case 7: money=5*8*0.75+2*8*0.95; break; case 8: money=4*8*0.8*2; break; case 9: money=5*8*0.75+4*8*0.8; break; } money=money+num1*5*8*0.75; printf("您购买的书的总价钱的:%g\n",money); printf("是否继续?继续请输入1,退出输入0\n"); scanf("%d",&jixu); switch(jixu) { case 0: printf("欢迎下次使用!\n"); break; case 1: goto a1; break; } return 0; }
相关文章推荐
- 使用javac编译Servlet类的方法
- margin padding border
- 让EditText不能自动获取焦点
- 墙相对移动
- 内联汇编
- mysql编程(存储过程和触发器)
- (转) Quick Guide to Build a Recommendation Engine in Python
- UVALive 4654 (最小路径覆盖)
- docker实践入门之四
- 计算器作业6
- XTU 1244 Estrella's Chocolate
- 周总结
- http://blog.csdn.net/dancing_night/article/details/46698853
- linux 之SCP
- JDBC中常用的的类和接口
- SQL优化
- 找水王02
- WEB开发中的AJAX请求
- javascript学习笔记
- 百万级查询性能优化