• 购书策略问题


    一、实验题目

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

    四、实验截图

    五、实验总结

          本实验整体思路不难,主要是从简单的情况开始分析,然后在进行总结归纳,寻找规律。

          对以后写程序的指导:从简单情况开始分析,寻找规律。

  • 相关阅读:
    Java Map遍历方式的选择
    UriMatcher类的addURI()方法
    Java IO流分析整理[转]
    java基础一些注意细节
    java中static变量和方存在内存什么区域
    详细解析Java中抽象类和接口的区别
    mybatis一些记录
    Go语言简介(上)— 语法
    JavaScript相关-深入面向对象
    33个组件5
  • 原文地址:https://www.cnblogs.com/seven-seven/p/5559524.html
Copyright © 2020-2023  润新知