码迷,mamicode.com
首页 > 其他好文 > 详细

课堂练习——书店折扣问题

时间:2016-06-22 18:56:45      阅读:234      评论:0      收藏:0      [点我收藏+]

标签:

1.设计题目

      书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元, 具体折扣如下所示:
                               本数                  折扣
                                   2                       5%
                                   3                       10%
                                   4                       20%
                                   5                       25%

2.设计要求

     根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。
     设计算法能够计算出读者购买一批书的最低价格。
要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。(截止日期2015-4-15晚18:00)

3.设计思想

    首先,能够确定的是5本一下的购买数量,买不同卷的书是最便宜的;

    然后,大于5本的需要分两种情况

          第一种:6~9本,他们需要考虑每个数量下,购买最便宜,例如:6本需要在1,5分,2,6分,3,3分找到最便宜的,其他的如上。

          第二种:大于9本的,举个例子,21本,分成5,5,5,6。就是前几个是5,最后一个是一个6-9的本数,根据上面的情况就可以简单求出这种情况的最大折扣了。

代码实现:

 1 #include<iostream.h>
 2 int main()
 3 {
 4  int i,d;
 5  double a[200];        //书本类型
 6  a[1]=8;
 7  a[2]=8*2*(1-0.05);
 8  a[3]=8*3*(1-0.10);
 9  a[4]=8*4*(1-0.20);
10  a[5]=8*5*(1-0.25);
11  do{
12   
13   cout<<"请输入买书本的数:";
14   int num;
15   
16   cin>>num;
17   
18  
19    double max[10];
20    max[1]=a[1]+a[5];
21    max[2]=a[2]+a[4];
22    max[3]=a[3]+a[3];
23    a[6]=max[1];
24    for(i=1;i<4;i++)
25    {
26     if(a[6]<max[i])
27     {
28      a[6]=max[i];
29     }
30    }
31   
32  
33    double max4=a[2]+a[5];
34    double max5=a[3]+a[4];
35    a[7]=(max4>max5)?max5:max4;
36   
37    double max6=a[3]+a[5];
38    double max7=a[4]*2;
39    a[8]=(max6>max7)?max7:max6;
40   
41  
42    a[9]=a[4]+a[5];
43   
44   if(num>9)
45   {
46    int b=(num/5)-1;
47    int m=5+num%5;
48 
49    a[num]=b*a[5]+a[m];
50    
51   
52   }
53 
54   cout<<"买这些书一共需花费:"<<a[num]<<"元!"<<endl;
55   cout<<"如果需要计算其他数量的价格请输1,否则0:";
56   cin>>d;
57   cout<<endl;
58  }while(d==1);
59  
60  return 0;
61 }

程序截图:

 技术分享

课堂练习——书店折扣问题

标签:

原文地址:http://www.cnblogs.com/ly199553/p/5607982.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!