Loading [MathJax]/jax/element/mml/optable/GeneralPunctuation.js

洛谷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\n%d", ans2, ans1); return 0; } ```

posted @   DAGGGGGGGGGGGG  阅读(130)  评论(0编辑  收藏  举报
编辑推荐:
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
阅读排行:
· Ollama本地部署大模型总结
· 2025成都.NET开发者Connect圆满结束
· langchain0.3教程:从0到1打造一个智能聊天机器人
· 用一种新的分类方法梳理设计模式的脉络
· C 语言内存布局深度剖析:从栈到堆,你真的了解吗?
历史上的今天:
2018-10-16 洛谷P1063能量项链题解
点击右上角即可分享
微信分享提示