问题:
书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数 | 折扣 |
2 | 5% |
3 | 10% |
4 | 20% |
5 | 25% |
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
设计算法能够计算出读者购买一批书的最低价格。
设计思想:
经过计算和分析,发现当购买1~5本书时按促销活动能以最低价格购买;当购买6~9本时,除了购买8本这种情况是以4本、4本来买为最低价格,其余只要以买5本为先就能计算出最低价格,所以分(number%5+5)是否等于8两种情况来考虑设计程序,若等于8则sum=2*4*8*0.8+(m-1)*8*5*0.75,其中m-1因为m=number/5这里m包含了8中的一个5;否则只要以买5本为先计算,再把n=number%5为1~4依次加上计算。
#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; } }