Sakurajima_Mai
2019-03-16 00:55:05
可以用三维
所以就可以递推一个关系式,分第
如果当
同理,
如果
递推方程为:
依次枚举在第
如果
如果
就是和刚开始的方向的无关,不用管朝哪个方向,只要走的最远的就行了,而且始终有两个相互对立的方向。初始化的时候
for (int i = 0; i <= len; i++)
for (int j = 0; j <= n; j++) dp[i][j][0] = dp[i][j][1] = -inf;
dp[0][0][0] = 0;//正方向
dp[0][0][1] = 0;//负方向,两边都可以走
for (int i = 1; i <= len; i++)
{
for (int j = 0; j <= n; j++)
{
for (int k = 0; k <= j; k++)
{
if (cmd[i] == 'F')
{
if (k & 1)
{
dp[i][j][0] = max(dp[i][j][0], dp[i - 1][j - k][1]);
dp[i][j][1] = max(dp[i][j][1], dp[i - 1][j - k][0]);
}
else
{
dp[i][j][0] = max(dp[i][j][0], dp[i - 1][j - k][0] + 1);
dp[i][j][1] = max(dp[i][j][1], dp[i - 1][j - k][1] - 1);
}
}
else
{
if (k & 1)
{
dp[i][j][0] = max(dp[i][j][0], dp[i - 1][j - k][0] + 1);
dp[i][j][1] = max(dp[i][j][1], dp[i - 1][j - k][1] - 1);
}
else
{
dp[i][j][0] = max(dp[i][j][0], dp[i - 1][j - k][1]);
dp[i][j][1] = max(dp[i][j][1], dp[i - 1][j - k][0]);
}
}
}
}
}