「Wdoi-(-1)」恋弹者们的黑集市

news/2024/9/29 20:32:14

「Wdoi-(-1)」恋弹者们的黑集市

魔理沙有两种方法移动这个骰子:将骰子向下一列翻转,或者向下一行翻转。值得注意的是,翻转骰子后,骰子每面上的数字就会随着翻滚而改变。现在魔理沙需要将骰子滚动至第 \(n\) 行第 \(m\) 列。

魔理沙的分数被定义为,所有时刻,骰子与棋盘上的数字接触的那一面的数字,乘上棋盘上该数字,再累加起来的和。只有魔理沙最大化这个和,她才能获取她所需要的卡片。

你能帮帮魔理沙吗?

简要题意

有一个 \(n\times m\) 大小的棋盘,第 \(i\) 行第 \(j\) 列写有数字 \(a_{i-1,j-1}\)

现在有一个骰子,六个面按照前、后、左、右、上、下的顺序,依次写有数字 \(w_0,w_1,w_2,w_3,w_4,w_5\)。现在骰子摆放在 \((0,0)\) 位置,需要将它滚动\((n-1,m-1)\)

骰子只有两种方式滚动:向下一行翻滚、向下一列翻滚。我们记一种方案的权值为,整个过程中(包括骰子在起点和终点时),骰子最底面上写着的数字,与此时骰子所在格子上写着的数字的乘积之和。

思路

\(dp\),我们很自然的会想到使用 \(dp_{i,j}\) 来表示骰子到达 \((i,j)\) 点的可以获得的最大权值,但是我们无法确定到达这一点时魔方的“方向”,这也就提示我们要把“魔方的状态”这个东西设计进转移方程式里面。

我们发现,我们只需要两个从正方体中心出发的两条垂直的有向射线就可以确定这个骰子的六个面了。

于是我们更改一下状态的设计,用 \(dp_{i,j,k,h}\) 表示骰子到了 \((i,j)\) 点,编号为 \(k\) 的面朝下,编号 \(h\) 的面朝前所能得到的最大权值。

我们知道 \(dp_{i,j}\) 会从 \(dp_{i - 1,j}\)\(dp_{i,j - 1}\) 转移过来,也就是说骰子会从右边翻过来或者从上面翻下来。

图示:

\((i,j)\)

\((i - 1,j)\) 翻下来:

\((i,j - 1)\) 翻到右边:

其中图 \(2\) 的状态是 \(dp_{i - 1,j,f(h),k}\),而图三的状态可以表示为 \(dp_{i.j - 1,g(h,k),h}\)

其中 \(f(h)\) 表示 \(h\) 面的对面,而 \(g(h,k)\) 表示以 \(h\) 面作为前面,\(k\) 面作为右边,这个状态立方体的下面。

\(f(h)\)\(g(h,k)\) 都可以提前预处理出来。

所以可以得到状态转移式:

\[dp_{i,j,k,h} = \max(dp_{i,j,k,h} , \max(dp_{i - 1,j,f(h),k},dp_{i,j - 1,g(h,k),h}) + w_k \times val_{i,j}) \]

此题完结,注意初始状态是第一张图的状态。

\(code\)

#include<iostream>
#include<algorithm>
using namespace std;
const int MAXN = 1e3 + 7;
const long long INF = -2e9;
const int rd[6] = {1,0,3,2,5,4};
const int cd[6][6] = {{-1 ,-1 ,4 ,5 ,3 ,2},{-1 ,-1 ,5 ,4 ,2 ,3},{5 ,4 ,-1 ,-1 ,0 ,1},{4 ,5 ,-1 ,-1 ,1 ,0},{2 ,3 ,1 ,0 ,-1 ,-1},{3 ,2 ,0 ,1 ,-1 ,-1},
};
int n,m;
int val[MAXN][MAXN];
int dp[MAXN][MAXN][6][6];
int w[MAXN];
int f(int x){ return rd[x]; }
int g(int h,int k){ return cd[h][k]; }
int main(){ios::sync_with_stdio(false);cin.tie(0);cin>>n>>m;for(int i = 1;i <= n;i++){for(int j = 1;j <= m;j++){cin>>val[i][j];}}for(int i = 0;i <= 5;i++){cin>>w[i];}for(int i = 0;i <= n;i++){for(int j = 0;j <= m;j++){for(int k = 0;k <= 5;k++){for(int h = 0;h <= 5;h++){dp[i][j][k][h] = INF;}}}}dp[1][1][5][0] = w[5] * val[1][1];for(int i = 1;i <= n;i++){for(int j = 1;j <= m;j++){if(i == j && i == 1) continue;for(int k = 0;k <= 5;k++){for(int h = 0;h <= 5;h++){if(g(h,k) == -1) continue;dp[i][j][k][h] = max(dp[i][j][k][h] , max(dp[i - 1][j][f(h)][k],dp[i][j - 1][g(h,k)][h]) + w[k] * val[i][j]);}}}}int ans = INF;for(int i = 0;i <= 5;i++){for(int j = 0;j <= 5;j++){ans = max(ans,dp[n][m][i][j]);}}cout<<ans;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/66302.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

腾讯企业邮箱(企业微信邮箱)迁移到microsoft 365(office 365)

1.迁移前准备(腾讯企业邮箱)1.如果你是企业管理员,首先看一下企业邮箱后台,是否已关闭 登陆安全2.登录要迁移的个人邮箱后台,关闭安全登录、开启IMAP服务和相关选项,以及为邮箱设置一个密码 2.开始迁移1.登录microsoft 365管理后台(https://admin.exchange.microsoft.com…

micropython +ESP32+ sht30 温湿度模块

SHT30 1)查找SHT30芯片资料 https://www.szlcsc.com 2)根据芯片资料,查得地址为 0x44 或 0x45 选 Measurement Commands for Single Shot Data Acquisition Mode, 命令为 0x2c10 3)连线SHT30 ESP32 D1(SCL) 4D2(SDA) 5 G …

系统固态扩容-全小白操作示意 不需要BIOS

机械革命有两个插槽,我有一个500G(系统盘)一个1T的固态,由于1.5T的固态都快用完了,所以买了一个2T的固态,将1T的内容迁移到2T中,将500G的迁移到1T中。 为了防止内容丢失先将500G系统盘做了备份,用的傲梅轻松备份。 1T->2T 然后就是将2T的固态用绿联的固态盒子先当做移…

2024-2025-1 20241318 《计算机基础与程序设计》第一周学习总结

这个作业属于哪个课程 <班级的链接>(如2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>(如2024-2025-1计算机基础与程序设计第一周作业)这个作业的目标 阅读浏览教材《计算机科学概论》并提出自己的问题,基于AI进行学习作业正文 ... 本博…

移除元素

第一个想法就是利用两个for循环暴力解决 #include <iostream> #include <vector> using namespace std; class Solution { public: int removeElement(vector<int>& nums, int val) { int size = nums.size(); int writeIndex = 0; // 用来记录…

学年(2024-2025-1) 学号(20241424)《计算机基础与程序设计》第一周学习总结

学年(2024-2025) 学号(20241424)《计算机基础与程序设计》第一周学习总结 作业信息 |这个作业属于2024-2025-1-计算机基础与程序设计)| |-- |-- | |这个作业要求在2024-2025-1计算机基础与程序设计第一周作业)| |这个作业的目标|<参考上面的学习总结模板,把学习过程通…

Qt - 文件操作3

8. QSettings8.1 简介 用户通常希望应用程序在会话中记住它的设置(窗口大小和位置,选项等)。 这些信息通常存储在Windows上的系统注册表中(HKEY_CURRENT_USERSoftware/MySoft ),以及macOS和iOS上的属性列表文件中。 在Unix系统上,在缺乏标准的情况下,许多应用程序(包括KDE应…

CSP模拟5

T1光 我们来考虑一个格加 \(4\) 或者减 \(4\) ,这样有一个比较好的性质,它能提供 \(4,2,2,1\) 的贡献还不会溢出,这样我们就有一个比较好的思路,我们枚举 \(4,2,2,1\) 所无法造成的贡献,很明显只有 \(16\) 种,然后我们就可以再枚举 \(4,2,2,1\) 来算贡献.点击查看代码 #in…