Dance Dance Revolution
今天我们来讲 Dance Dance Revolution这题
本题原网址
注意本题为多组输入输出,直到输入单个零而止(题面有点小问题)
很明显,此题为一道动态规划题(请不要妄想用贪心算法过这题,尽管你可能可以过样例,但是面对你的依然是WA),首先要存一个cost数组,用于存储从i号点到j号点的花费,存储过程如下
int cost[5][5];
void cost_put()
{
for(int i=0;i<=4;i++)cost[i][i]=1;
for(int i=1;i<=3;i++)cost[i][i+1]=cost[i+1][i]=3;
cost[4][1]=cost[1][4]=3,cost[3][1]=cost[1][3]=cost[2][4]=cost[4][2]=4;
for(int i=1;i<=4;i++)cost[0][i]=cost[i][0]=2;
}
存储完后,就该想想状态的描述,很显然,我们不仅需要描述他左脚和右脚的位置,还需要描述已经踩到了第几个音符。
因此要开一个三维的dp数组,\(dp[i][j][k]\)表示踩完第i个后,左脚在i号点,右脚在j号点,所需的最小花费。
想好了状态后,接着初始化,过程如下
scanf("%d",&x);
for(int i=1;i<=100000;i++)
for(int j=0;j<=4;j++)
for(int k=0;k<=4;k++)
dp[i][j][k]=1e9;
dp[0][0][0]=0;dp[1][x][0]=dp[1][0][x]=2;
该想转移方程了,在纸上画一画,很容易想到如下的转移方程(注意以下两个方程的细微差别)
dp[tot][x][i]=min(dp[tot-1][j][i]+cost[x][j],dp[tot][x][i]);
//正准备踩第i个,此时左脚踩到要踩的点,右脚踩在i号点上,所需的最小花费
dp[tot][i][x]=min(dp[tot-1][i][j]+cost[x][j],dp[tot][i][x]);
//正准备踩第i个,此时右脚踩到要踩的点,左脚踩在i号点上,所需的最小花费
想到这里已经没有什么可以难倒你了,但是有以下几点要注意:
2.\(dp\)数组和\(ans\)变量的初始值一定要设成极大值,因为要取最小值(算最小的花费值当然是取最小值)
3.最后\(ans\)一定取值时要在除去\(dp[tot][0][0],dp[tot][1][1],dp[tot][2][2],dp[tot][3][3],dp[tot][4][4]\)(\(tot\)为歌曲总长度)这几个状态的答案,这些状态违反了题目中两脚不可以同时踩在同一点的规则
完整代码:
#include<bits/stdc++.h>
using namespace std;
int x,cost[5][5],dp[100010][5][5],tot=1,ans=1e9;
void cost_put()
{
for(int i=0;i<=4;i++)cost[i][i]=1;
for(int i=1;i<=3;i++)cost[i][i+1]=cost[i+1][i]=3;
cost[4][1]=cost[1][4]=3,cost[3][1]=cost[1][3]=cost[2][4]=cost[4][2]=4;
for(int i=1;i<=4;i++)cost[0][i]=cost[i][0]=2;
}
int main()
{
cost_put();
while(true)
{
scanf("%d",&x);
if(x==0)break;
tot=1;ans=1e9;
for(int i=1;i<=100000;i++)
for(int j=0;j<=4;j++)
for(int k=0;k<=4;k++)
dp[i][j][k]=1e9;
dp[0][0][0]=0;dp[1][x][0]=dp[1][0][x]=2;
//初始化
while(x!=0)
{
scanf("%d",&x);
tot++;
for(int i=0;i<=4;i++)
for(int j=0;j<=4;j++)
dp[tot][x][i]=min(dp[tot-1][j][i]+cost[x][j],dp[tot][x][i]);
for(int i=0;i<=4;i++)
for(int j=0;j<=4;j++)
dp[tot][i][x]=min(dp[tot-1][i][j]+cost[x][j],dp[tot][i][x]);
}
//转移
tot--;
for(int i=0;i<=4;i++)
for(int j=0;j<=4;j++)
if(i!=j)ans=min(ans,dp[tot][i][j]);
//统计答案
printf("%d\n",ans);
}
return 0;
}
Dance Dance Revolution的更多相关文章
- UVA 1291 十四 Dance Dance Revolution
Dance Dance Revolution Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Su ...
- [LA] 2031 Dance Dance Revolution
Dance Dance Revolution Time limit: 3.000 seconds Mr. White, a fat man, now is crazy about a game nam ...
- 递推DP UVA 1291 Dance Dance Revolution
题目传送门 题意:给一串跳舞的动作,至少一只脚落到指定的位置,不同的走法有不同的体力消耗,问最小体力消费多少分析:dp[i][j][k] 表示前i个动作,当前状态(j, k)的最小消费,状态转移方程: ...
- 2000 Asia shanghai Dance Dance Revolution
思路:dp[i][x][y]表示第i个序列中,右脚在x位置,左脚在y位置时,其最小花费. 那么dp[i][x][y]=min(dp[i-1][a[i]][y]+cost[a[i]][x],dp[i-1 ...
- UVA 1291 Dance Dance Revolution(DP)
意甲冠军:跳舞机有一个上5积分,分别central, top, bottom, left, right分,区区足站立还是需要1点物理,从一个单纯的脚central点上须要2点体力,从一个点上移动到相邻 ...
- UVALive - 2031 Dance Dance Revolution 三维dp
题目大意:有一个胖子在玩跳舞机.刚開始的位置在(0,0).跳舞机有四个方向键,上左下右分别相应1,2,3,4.如今有下面规则 1.假设从0位置移动到随意四个位置,消耗能量2 2.假设从非0位置跳到相邻 ...
- TCP/UDP端口列表
http://zh.wikipedia.org/wiki/TCP/UDP%E7%AB%AF%E5%8F%A3%E5%88%97%E8%A1%A8 TCP/UDP端口列表 本条目可通过翻译外语维 ...
- LA 2031
Mr. White, a fat man, now is crazy about a game named ``Dance, Dance, Revolution". But his danc ...
- HTML简单介绍及常见元素
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- laravel服务容器 转
laravel框架底层解析 本文参考陈昊<Laravel框架关键技术解析>,搭建一个属于自己的简化版服务容器.其中涉及到反射.自动加载,还是需要去了解一下. laravel服务容器 建立项 ...
- js 如何获取浏览器的高度?
<SCRIPT LANGUAGE="JavaScript"><!--var s = ""; s += " 网页可见区域宽:" ...
- 第六章 Linux系统之文件管理
一.文件管理概述 1.对文件做些什么? 谈到Linux文件管理,首先我们需要了解的就是,我们要对文件做些什么事情? 其实无非就是对一个文件进行创建.复制.移动.查看.编辑.压缩.查找.删除等等 2.内 ...
- Linux系统安装MySQL(2020最新最详细)
2020最新Linux系统发行版ContOS7演示安装MySQL. 为防止操作权限不足,建议切换root用户,当然如果你对Linux命令熟悉,能够自主完成权限更新操作,可以不考虑此推荐. 更多命令学习 ...
- Luogu P2173 [ZJOI2012]网络
题意 写的比较清楚,我就不解释了. \(\texttt{Data Range:}n\leq 10^4,m\leq 10^5,c\leq 10,k\leq 10^5\) 题解 注意到 \(c\) 的范围 ...
- 【CF1445D】Divide and Sum 题解
题目链接 题意简介 将一个长度为 2n 的数列平均分为两个子数列 p 和 q 后,p 按从小到大排序,q 按从大到小排序. 排序后,记 p 为 \(\{x_i\}\) ,q 为 \(\{y_i\}\) ...
- Java学习的第六天
1.今天学习了各种运算符, 还有选择结构,循环结构 2.今天学习没有遇到困难. 3.明天学习数组和第三章的开头一部分.
- Flask中的RESTFul
RESTFul 1.什么是RESTFul? 1.1 简介 REST即表述性状态传递(英文:Representational State Transfer, 简称REST)是Roy Fielding博士 ...
- win10右键打开PowerShell
win10右键打开PowerShell 转载自:http://www.xitongzhijia.net/xtjc/20170526/98756.html 如图: 1.首先在桌面新建一个txt文文件 复 ...
- active cab inf文件编写
最近做了一个网页下载控件.主要就是实现ActiveX控件功能. 由于自己是第一次做,不熟悉其过程.中间走了很多弯路.现在把走过得路程记录部分,希望对其他人可以有点用. 首先制作一个你自己的DLL文件. ...