• 51nod 1270 数组的最大代价


    数组A包含N个元素A1, A2......AN。数组B包含N个元素B1, B2......BN。并且数组A中的每一个元素Ai,都满足1 <= Ai <= Bi。数组A的代价定义如下:
     
     
    (公式表示所有两个相邻元素的差的绝对值之和)
    给出数组B,计算可能的最大代价S。
    Input
    第1行:1个数N,表示数组的长度(1 <= N <= 50000)。
    第2 - N+1行:每行1个数,对应数组元素Bi(1 <= Bi <= 10000)。
    Output
    输出最大代价S。
    Input示例
    5
    10
    1
    10
    1
    10
    Output示例
    36

    若想使相邻两数之差(绝对值)的和最大,在Ai-1确定时,Ai  的取值只有两种情况:最小(1)或最大(Bi
    dp1[max_n]:表示第Ai取最大值Bi
    dp2[max_n];表示Ai取最小值1
    由此可得到递推关系:
    dp1[i]=max(dp1[i-1]+abs(b[i]-b[i-1]),dp2[i-1]+(b[i]-1));
    dp2[i]=max(dp1[i-1]+abs(b[i-1]-1),dp2[i-1]);
    ans=max(dp1[n-1],dp2[n-1])
     1 #include<iostream>   //差值和最大,每项取bi或1
     2 #include<algorithm>
     3 #include<string>
     4 #include<string.h>
     5 using namespace std;
     6 int dp1[50005];//取bi
     7 int dp2[50005];//取1
     8 int n, b[50005];
     9 int main()
    10 {
    11     while (cin >> n)
    12     {
    13         for (int i =0 ; i < n; i++)
    14             cin >> b[i];
    15         memset(dp1, 0, sizeof(dp1));
    16         memset(dp2, 0, sizeof(dp2));
    17         for (int i = 1; i < n; i++)
    18         {
    19             dp1[i] = max(dp2[i - 1] + abs(b[i] - 1), dp1[i - 1] + abs(b[i] - b[i - 1])); //第i项取bi
    20             dp2[i] = max(dp1[i - 1] + abs(b[i - 1] - 1), dp2[i - 1]);                    //第i项取1
    21         }
    22         cout << max(dp1[n-1], dp2[n-1]) << endl;;
    23     }
    24     return 0;
    25 }
    
    

     

  • 相关阅读:
    Spring事务管理
    Java GC算法
    内连接,左连接,右连接
    ThreadLocal相关
    @Autowired 与 @Resource的区别
    spring注解
    BZOJ 1040 ZJOI 2008 骑士 树形DP
    HDU 5575 Discover Water Tank 并查集 树形DP
    BZOJ 3571 画框 KM算法 最小乘积最大权匹配
    ZOJ 3256 Tour in the Castle 插头DP 矩阵乘法
  • 原文地址:https://www.cnblogs.com/Egoist-/p/7390674.html
Copyright © 2020-2023  润新知