zoukankan      html  css  js  c++  java
  • 洛谷P1043数字游戏

    题目

    区间DP,将(maxn[i][j][k])表示为i到j区间内分为k个区间所得到的最大值,(minn)表示最小值。

    然后可以得到状态转移方程:

    [maxn[i][j][k]= max(maxn[i][j][k],maxn[i][l][k-1]*(l到j的\%10后的和))$$。 然后判断一下边界就能得到最终答案。 ```c++ #include <bits/stdc++.h> using namespace std; int n, m, data[1001010]; int sum[111], ha[111][111];//每一段区间的和 int maxn[111][111][111], minn[111][111][111]; int ans1, ans2 = 2147483647; int main() { scanf("%d%d", &n, &m); for (int i = 1; i <= n; i++) { scanf("%d", &data[i]); data[i + n] = data[i]; } n *= 2; for (int i = 1; i <= n; i++) sum[i] = sum[i - 1] + data[i]; memset(minn, 12, sizeof(minn)); for (int i = 1; i <= n; i++) for (int j = i + 1; j <= n; j++) ha[i][j] = (sum[j] - sum[i] + 100000) % 10, maxn[i][j][1] = minn[i][j][1] = ha[i][j]; for (int k = 2; k <= m; k++) for (int i = 1; i <= n; i++) for (int j = i + k - 1; j <= n; j++) { minn[i][j][k] = 214748367; for (int l = i + k - 2; l < j; l++) { maxn[i][j][k] = max(maxn[i][l][k - 1] * ha[l][j], maxn[i][j][k]); minn[i][j][k] = min(minn[i][l][k - 1] * ha[l][j], minn[i][j][k]); } } for (int i = 1; i <= n / 2; i++) ans1 = max(maxn[i][i + n / 2][m], ans1), ans2 = min(minn[i][i + n / 2][m], ans2); printf("%d %d", ans2, ans1); return 0; } ```]

  • 相关阅读:
    P4910 帕秋莉的手环
    P3216 [HNOI2011]数学作业
    洛谷 P2894 [USACO08FEB]酒店
    [网络流24题]魔术球问题
    [网络流24题]飞行员配对方案问题
    [网络流24题]最小路径覆盖问题
    洛谷 P1503鬼子进村
    BZOJ 3631: [JLOI2014]松鼠的新家
    洛谷 P2922 [USACO08DEC]秘密消息Secret Message
    洛谷 P1379 八数码难题
  • 原文地址:https://www.cnblogs.com/liuwenyao/p/11685976.html
Copyright © 2011-2022 走看看