博客
关于我
Python-CSP 201709-1 打酱油
阅读量:651 次
发布时间:2019-03-15

本文共 950 字,大约阅读时间需要 3 分钟。

打酱油优化算法

目录

算法思想

购物策略选择

对于打酱油的购买选择,我们有三种方案可供选择:

  • 买五送二
  • 买三送一
  • 原价购买
  • 在有限预算N下的购买策略优化,应优先选择能够获得最大价值的购买方案。具体规则如下:

    五送二优惠方案

    对于预算N元的情况,若N>=50元时,优先选择五送二方案:

    • 实际购买数量:每次购买可获得5瓶酱油,需支付50元。
    • 赠送数量:每次购买赠送2瓶酱油。
    • 购买次数:可通过N//50计算。
    • 金额消耗:每次购买消耗50元,剩余金额为N % 50元。

    三送一优惠方案

    当预算N不足以支持五送二方案时,即N>=30元时,选择三送一方案:

    • 实际购买数量:每次购买可获得3瓶酱油,需支付30元。
    • 赠送数量:每次购买赠送1瓶酱油。
    • 购买次数:可通过N//30计算。
    • 金额消耗:每次购买消耗30元,剩余金额为N % 30元。

    原价购买方案

    如果预算余额仍然不足以支持以上优惠方案时,仅能选择原价购买:

    • 每瓶价格为10元。
    • 在剩余金额N // 10的情况下,购买N//10瓶酱油。

    代码实现

    以下是对于该优化算法的Python代码实现:

    # encoding: utf-8# 作者:小狐狸if __name__ == "__main__":    N = int(input())    num = 0  # 瓶数        if N >= 50:  # 五送二优惠方案        buy_times = N // 50        num += buy_times * 5 + buy_times * 2        N %= 50            if N >= 30:  # 三送一优惠方案        buy_times = N // 30        num += buy_times * 3 + buy_times * 1        N %= 30            if N >= 10:  # 原价购买        num += N // 10        N %= 10            print(num)

    结论

    通过上述算法和优化策略,我们能够在给定预算N下,最大化购买酱油的数量。如果需要更详细的步骤说明或扩展更多功能,请参考完整文档。

    转载地址:http://rhcmz.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>