买书方案

一、题目要求

书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
本数  2      3      4       5    折扣  5%   10%    20%   25%                                                 
根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
设计算法能够计算出读者购买一批书的最低价格。

二、设计思想

 

由分析可得,大于十时,均可转化为6.7.8.9.10的情况。

三、代码实现

//2016.6.6买书方案
//20143066 毛雯雯
#include<iostream>
using namespace std;
double num1(int a)
{   //买书的本数为6、7、8、9
   double sum1;
   switch(a%5)
   {
		case 1:
			sum1=5*8*0.75+8;break;
		case 2:
			sum1=5*8*0.75+2*8*0.95;break;
		case 3:
			sum1=4*8*0.8+4*8*0.8;break;
		case 4:
			sum1=5*8*0.75+4*8*0.8;break;   
   }
	return sum1;   //返回最大折扣
}

int main(int argc, char* argv[])
{
    int num;
    double sum;   //最大折扣
    cout<<"请输入您要购买的本数:";
    cin>>num;
    if(num<=5)
    {
       switch(num)
       {
			case 1:
				sum=8;break;
			case 2:
				sum=2*8*0.95;break;
			case 3:
				sum=3*8*0.9;break;
			case 4:
				sum=4*8*0.8;break;
			case 5:
				sum=5*8*0.75;break;
       }
    }
    if((num>5)&&(num<10))
    {
        sum=num1(num);      //大于5小于10时,调用num1函数
    }
    if(num>9)             //大于等于10之后的,可以转化为6、7、8、9的情况计算
    {
        switch(num%5)
       {
        case 0:
            sum=(num/5)*8*5*0.75;break;
       case 1:
           sum=(num/5-1)*5*8*0.75+num1(6);break;
       case 2:
           sum=(num/5-1)*8*5*0.75+num1(7);break;
       case 3:
           sum=(num/5-1)*8*5*0.75+num1(8);break;
       case 4:
           sum=(num/5-1)*8*5*0.75+num1(9);break;
       }
    }
   cout<<"最大折扣价为:"<<sum;
   cout<<endl;
   return 0;

}

 

四、实现截图

 

五、个人总结

一定要多分析!!!

posted @ 2016-06-16 09:31  justMww  阅读(267)  评论(0编辑  收藏  举报