zoukankan      html  css  js  c++  java
  • 课堂练习-最低价购书方案

    问题:

      书店针对《哈利波特》系列书籍进行促销活动,一共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; 
        } 
    }

  • 相关阅读:
    如何把phpStorm打造成自己的专属IDE?
    PHP伪造referer突破网盘禁止外链(附115源码)
    PHP实现删除非站内外部链接实例代码
    Http Referer的一些总结
    jquery 选择器(name,属性,元素)大全
    Invoke 和 BeginInvoke 的真正涵义
    C# HashSet集合类型使用介绍
    Dev系列控件的AJAX使用Demo
    如何进行SVN数据迁移并保存版本号数据
    Window及document对象
  • 原文地址:https://www.cnblogs.com/0jiajia1/p/5606063.html
Copyright © 2011-2022 走看看