zoukankan      html  css  js  c++  java
  • [BJOI2019]排兵布阵 DP

    [BJOI2019]排兵布阵 DP

    比较好想的DP,设(dp[i][j])表示第(i)个城堡时,已派出(j)个士兵。决策时,贪心派出恰好严格大于某一玩家派出的数量的两倍(不然浪费)。我们发现又可以排序预处理出(a[i][j])表示第(i)个城堡,出兵数量第(j)大的人出兵数量(因为这样可以很容易算出贡献,即为(k imes i)

    dp转移方程即为:

    [dp[j]=MAX(dp[j-a[i][k]*2-1]+k*i, dp[j]); ]

    AC Code:

    #include <cstdio>
    #include <algorithm>
    #define MAX(A,B) ((A)>(B)?(A):(B))
    using namespace std;
    int s,n,m,dp[20002],a[110][110],ans;
    signed main(){
        scanf("%d %d %d", &s, &n, &m);
        for(int i=1;i<=s;++i)
            for(int j=1;j<=n;++j)
                scanf("%d", &a[j][i]);
        for(int i=1;i<=n;++i)
            sort(a[i]+1, a[i]+1+s);
        for(int i=1;i<=n;++i)
            for(int j=m;j>=0;--j)
                for(int k=1;k<=s;++k)
                    if(j>a[i][k]*2)
                        dp[j]=MAX(dp[j-a[i][k]*2-1]+k*i, dp[j]);
        for(int i=0;i<=m;++i) ans=MAX(ans, dp[i]);
        printf("%d
    ", ans);
        return 0;
    }
    /*
     dp[i][j]第i个城堡时,已派出j个士兵
     a[i][j]第i个城堡,第j个人出的兵
     */
    
  • 相关阅读:
    float
    老师的通病
    无题
    BufferedReader
    剩余定理
    ActionScript 多图加载 按图顺序索引
    C++ Socket 编程
    设计高可用和高负载的网站系统
    提高网站速度的最佳实践【翻译】
    把哈希表存储到数据库中
  • 原文地址:https://www.cnblogs.com/santiego/p/11184624.html
Copyright © 2011-2022 走看看