博客
关于我
Employment Planning
阅读量:192 次
发布时间:2019-02-28

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

为了解决这个问题,我们需要确定在每个月雇佣或解雇工人时的最小总成本。这个问题可以通过动态规划来解决,具体步骤如下:

方法思路

  • 状态定义:使用二维数组 f[i][j] 表示前 i 个月,第 i 个月恰好有 j 名工人时的最小总成本。
  • 状态转移
    • 如果雇佣人数增加,计算雇佣新员工的成本。
    • 如果解雇人数减少,计算解雇员工的成本。
  • 初始条件:第一个月必须雇佣至少 min_worker 名工人。
  • 优化:预处理每个月的最小员工需求,限制 j 的范围,减少状态空间。
  • 解决代码

    #include 
    #include
    #include
    #include
    #include
    #include
    #include
    using namespace std;int main() { int n, hire, salary, fire; while (cin >> n && n != 0) { int min_worker[] = {0}, maxn = 0; for (int i = 1; i <= n; ++i) { cin >> min_worker[i]; if (min_worker[i] > maxn) maxn = min_worker[i]; } cin >> hire >> salary >> fire; int size = maxn + 1; int f[n+1][size]; for (int i = 0; i <= n; ++i) { for (int j = 0; j <= size; ++j) { f[i][j] = 1e9; } } for (int j = min_worker[1]; j <= maxn; ++j) { f[1][j] = (hire + salary) * j; } for (int i = 2; i <= n; ++i) { for (int j = min_worker[i]; j <= maxn; ++j) { for (int k = min_worker[i-1]; k <= maxn; ++k) { if (j > k) { if (f[i][j] > f[i-1][k] + (j - k) * hire + j * salary) { f[i][j] = f[i-1][k] + (j - k) * hire + j * salary; } } else { if (f[i][j] > f[i-1][k] + (k - j) * fire + j * salary) { f[i][j] = f[i-1][k] + (k - j) * fire + j * salary; } } } } } int ans = 1e9; for (int j = min_worker[n]; j <= maxn; ++j) { if (f[n][j] < ans) { ans = f[n][j]; } } cout << ans << endl; }}

    代码解释

  • 读取输入:读取每个测试用例的数据,直到遇到0。
  • 预处理最小员工需求:找出每个月的最小员工需求,并确定最大人数。
  • 初始化动态规划数组f[i][j] 初始化为一个很大的值,表示最小成本。
  • 第一个月的处理:计算雇佣至少 min_worker 名工人的成本。
  • 状态转移:对于每个月,计算每种可能的员工人数,并更新最小成本。
  • 结果计算:找到最后一个月的最小成本作为答案。
  • 通过这种方法,我们可以高效地确定每个月的最优员工配置,实现最小总成本。

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

    你可能感兴趣的文章
    oracle 查询clob
    查看>>
    oracle 行转列
    查看>>
    Oracle 表
    查看>>
    Oracle 递归
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>