购书策略问题
一、实验题目
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数 折扣
2 5%
3 10%
4 20%
5 25%
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
设计算法能够计算出读者购买一批书的最低价格。
二、实现方法及设计思路
首先分析购买前十本的不同情况:
购买
1本:8
2本:16*0.95=15.2
3本:24*0.9=21.6
4本:32*0.8=25.6
5本:40*0.75=30
6本:30+8=38 分成5本和1本购买
7本:30+15.2=45.2 分成5本和2本购买
8本:25.6*2=51.2 4和4 分成4本和4本购买
9本:55.6 分成5本和4本购买
10本:60
根据上述分析,可知对于总的购买数量count,可以以10本分组,A=count/10;B=count%10(求余);总钱数=A*60+根据B获得的策略价钱;
三、实验代码
#include<iostream> #include<string> using namespace std; int main() { int intNum = 0; //定义购买的数量 int intYushu = 0; //判断条件,余数 int intShang = 0; //商 double intJiaqian = 0; //总的价钱 int intTemp = 0; //整数价钱 int celue1 = 0; int celue2 = 0; //购买策略 cout << "请输入购买的书籍的数量:"; cin >> intNum; intYushu = intNum % 10; intShang = intNum / 10; intTemp = 60 * intShang; switch (intYushu) { case 0: intJiaqian = intTemp; celue1 = 0; celue2 = 0; break; case 1: intJiaqian = intTemp + 8; celue1 = 1; celue2 = 0; break; case 2: intJiaqian = intTemp + 15.2; celue1 = 2; celue2 = 0; break; case 3: intJiaqian = intTemp + 21.6; celue1 = 3; celue2 = 0; break; case 4: intJiaqian = intTemp + 25.6; celue1 = 4; celue2 = 0; break; case 5: intJiaqian = intTemp + 30; celue1 = 5; celue2 = 0; break; case 6: intJiaqian = intTemp + 38; celue1 = 1; celue2 = 5; break; case 7: intJiaqian = intTemp + 45.2; celue1 = 2; celue2 = 5; break; case 8: intJiaqian = intTemp + 51.2; celue1 = 4; celue2 = 4; break; case 9: intJiaqian = intTemp + 55.6; celue1 = 4; celue2 = 5; break; default: break; } cout << "最低价格为:" << intJiaqian << endl; cout << "购买策略为:" << endl; cout << "剩下的不足10本的书分成" << celue1 << "本和" << celue2 << "本购买。"<<endl; return 0; }
四、实验截图
五、实验总结
本实验整体思路不难,主要是从简单的情况开始分析,然后在进行总结归纳,寻找规律。
对以后写程序的指导:从简单情况开始分析,寻找规律。