博客
关于我
【倍增dp】P3462 [POI2007]ODW-Weights
阅读量:303 次
发布时间:2019-03-03

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

砝码的质量通常是按倍数递增的,比如常见的1、2、4等。这种特性使得我们可以将容器的容量表示为多进制的形式。例如,使用1、2、4这样的砝码,容器的容量可以表示为(2,0,1)。接下来,我们需要将所有盒子的进制数组合并,并累加每个进制位的最大容量。

在实现上,我们可以采用贪心算法来处理每个砝码。具体步骤如下:

  • 去重处理:首先对砝码进行去重,确保每个砝码的重量唯一。

  • 进制转换:将每个盒子的容量转换为对应的进制形式。对于每个砝码,计算其在当前进制位上的最大容量,并累加到总和中。

  • 处理进制位:从高位到低位依次处理每个进制位。如果当前进制位有值,直接将其加入总和;如果没有值,寻找其前面最近的有值的进制位,并借用该值来计算当前位的容量。

  • 通过这种方法,我们可以高效地计算出所有盒子的进制数组的总和,并确定每个进制位的最大容量。这种贪心策略不仅简化了计算过程,还能确保结果的准确性。

    以下是代码实现的核心逻辑:

    #include 
    using namespace std;const int maxn = 100001;int a[maxn], box[maxn], n, m, aa[maxn], ans, k, cnt, flag = 1, f[33];bool cmp(int a, int b) { return a > b; }int main() { scanf("%d%d", &n, &m); for (int i = 1; i <= n; i++) scanf("%d", &box[i]); for (int i = 1; i <= m; i++) scanf("%d", &a[i]); sort(a + 1, a + 1 + m, cmp); for (int i = 1; i <= m; i++) { if (a[i] != a[i - 1]) aa[++cnt] = a[i]; } for (int i = 1; i <= n; i++) { for (int k = 1; k <= cnt; k++) { f[k] += box[i] / aa[k]; box[i] %= aa[k]; } } f[0] = 1; sort(a + 1, a + 1 + m); for (int i = 1; i <= m; i++) { int x = a[i]; for (int j = cnt; j >= 1; j--) { if (aa[j] < x) continue; for (k = j; k >= 1; k--) { if (aa[k] < x || !f[k]) continue; if (!f[k]) { for (p = k; p >= 1; p--) { if (aa[p] <= x) { f[k] -= f[p]; x -= aa[p] * f[p]; } } if (!f[k]) { printf("%d\n", ans); return 0; } } } } } printf("%d\n", ans); return 0;}

    代码主要包含以下几个部分:

  • 输入处理:读取输入数据并解析。

  • 去重处理:对砝码进行去重,得到唯一的砝码重量。

  • 进制转换:将每个盒子的容量转换为对应的进制形式。

  • 贪心处理:从高位到低位处理每个进制位,计算总和并输出结果。

  • 通过上述方法,我们可以高效地解决问题,并确保结果的准确性。

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

    你可能感兴趣的文章
    PFX(Parallel Framework) and Traditional Multithreading
    查看>>
    PGOS:今天动手给电脑装青苹果Win7 X64位系统
    查看>>
    pgpool-II3.1 的内存泄漏(一)
    查看>>
    PgSQL · 特性分析 · PG主备流复制机制
    查看>>
    PGSQL主键序列
    查看>>
    PGSQL安装PostGIS扩展模块
    查看>>
    pg数据库中两个字段相除
    查看>>
    PhalApi:[1.23] 请求和响应:GET和POST两者皆可得及超越JSON格式返回
    查看>>
    Phalcon环境搭建与项目开发
    查看>>
    Phantom.js维护者退出,项目的未来成疑
    查看>>
    Pharmaceutical的同学们都看过来,关于补码运算的复习相关内容
    查看>>
    Phaser性能测试加强版
    查看>>
    phoenix 开发API系列(一)创建简单的http api
    查看>>
    Phoenix 查看表信息及修改元数据
    查看>>
    phoenixframework集成了所有自动化测试的思想的平台。mark一下。
    查看>>
    phoenix_执行sql报错_Error: ERROR 504 (42703): Undefined column. columnName=(state=4270_大数据工作笔记0181
    查看>>
    phoenix启动失败_The history file `/root/.sqlline/history` may be an older history---记录024_大数据工作笔记0184
    查看>>
    Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
    查看>>
    phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
    查看>>
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>