“炫舞家“ST

时间限制: 3000 ms  |  内存限制: 65535 KB
难度: 3
描述
ST是一个酷爱炫舞的玩家。TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机(Dance Dance Revolution,DDR)。但是TA每天还要努力的学习,因此TA希望每次都保存最多的体力来学习。

DDR的主要内容是用脚来踩踏板。踏板有4个方向的箭头,用1,2,3,4来代表,如下图所示。

游戏规则如下:
   每首歌曲有一个箭头序列,游戏者必须按照这个序列依次用某一只脚踩相应的踏板。在任何时候,两只脚都不能在同一个踏板上,但可以同时待在中心位置0(一开始游戏的时候,游戏者的双脚都在中心位置0处)。
   每一个时刻,TA必须移动而且只能移动TA的一只脚去踩相应的箭头,而另一只脚不许移动。这样,TA跳DDR的方式可以用一串数字L1L2………Ln来表示。
   其中体力消耗规则如下:
1、 从中心往任何一个箭头耗费2个单位体力;
2、 从任何一个箭头移动到相邻箭头耗费3个单位体力(1和3相对,2和4相对)耗费4个单位体力。
3、 留在原地在踩一下只需要1单位。 
现在炫舞家ST很想学习但是又想玩DDR。因此,TA希望厉害的程序员你可以帮TA编写一个程序计算出TA因该怎样移动他的双脚(即,对于每个箭头,选一只脚去踩它),才能用最少的体力完成给定的舞曲。
例如,给出22140,总的体力耗费为2+1+2+3=8单位。

输入
输入文件将包括一系列的方向序列。每个方向序列包含一个数字序列。每个输入序列应该是数字1、2、3或4,每个代表四个方向之一。一个值为0的方向序列表示方向的结束序列。和这个值应该被排除在方向序列(每个方向序列输入最多包含10000个数字)。输入文件结束为输入序列只有单独的一个0。
输出
对于每个方向序列,输出最少单位的体力消耗值。结果应该是一个整数在单独的一行。任何多余的白空格或空行将不被接受。
样例输入
2 3 3 3 3 1 2 0
3 2 2 1 2 0
0
样例输出
12
9

一开始以为贪心可以过,然而是我想的太简单了。每移动一次,都需要记录左脚和右脚的状态和对应的消耗,把左脚右脚所有状态对应的消耗都dp出来,可以用三维dp来存储。dp[i][j][k]表示第i次移动时,左脚位于j,右脚位于k,对应的消耗。

假设本次需要移动到x点,那么转移方程为:

dp[i][j][x]=min(dp[i-1][j][k]+val[k][x],dp[i][j][x]);
dp[i][x][j]=min(dp[i-1][k][j]+val[k][x],dp[i][x][j]);

代码:

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define inf 1<<29
int dp[10005][5][5],val[5][5];
int main()
{val[1][1]=val[2][2]=val[3][3]=val[4][4]=1;val[0][1]=val[0][2]=val[0][3]=val[0][4]=2;val[1][2]=val[2][1]=val[2][3]=val[3][2]=val[3][4]=val[4][3]=val[4][1]=val[1][4]=3;val[1][3]=val[3][1]=val[2][4]=val[4][2]=4;while(1){int x;for(int k=0; k<=10000; k++)for(int i=0; i<=4; i++)for(int j=0; j<=4; j++)dp[k][i][j]=inf;dp[0][0][0]=0;int i;for(i=1;; i++){scanf("%d",&x);if(i==1 && x==0)return 0;if(x==0)break;for(int j=0; j<=4; j++){for(int k=0; k<=4; k++){dp[i][j][x]=min(dp[i-1][j][k]+val[k][x],dp[i][j][x]);dp[i][x][j]=min(dp[i-1][k][j]+val[k][x],dp[i][x][j]);}}}int minn=inf;for(int j=0;j<=4;j++)for(int k=0;k<=4;k++)minn=min(minn,dp[i-1][j][k]);printf("%d\n",minn);}return 0;
}

nyoj-740 “炫舞家“ST相关推荐

  1. NYOJ 740 “炫舞家”ST

    "炫舞家"ST 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...

  2. 题目 740 “炫舞家“ST

    "炫舞家"ST 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...

  3. nyist 740 “炫舞家“ST

    题目地址:http://acm.nyist.net/JudgeOnline/problem.php?pid=740 思路: #include <iostream> #include < ...

  4. NYOJ740 - “炫舞家“ST (DP)

    题目链接  NYOJ740 [题意] "炫舞家"ST 时间限制:3000 ms  |            内存限制:65535 KB 难度:3 描述 ST是一个酷爱炫舞的玩家.T ...

  5. nyoj740“炫舞家“ST【dp】

    "炫舞家"ST 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...

  6. nyistOJ-“炫舞家“ST(DP)

    "炫舞家"ST 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...

  7. 90 后董事长的国内首个元宇宙婚礼!网友:不由得想起了 QQ 炫舞和飞车......

    整理 | 郑丽媛 出品 | 程序人生(ID:coder_life) 在你的设想中,一场特别的婚礼应该是怎样的?拥有独一无二的主题,穿着打破陈规的服饰,还是举办在出其不意的地点? 10 月 8 日,国内 ...

  8. 中手游署理《每天炫舞》内测 前进精品手游商场

    署理的以交际娱乐为主的舞蹈类手游<每天炫舞>将于4月18日在91帮手.安卓商场.baidu多酷.安智商场.当乐.UC.360.豌豆荚等多家渠道进行不删档内测,中国手游官网也供给游戏包供玩家 ...

  9. 【绿色qq炫舞记忆助手心动版】增加社区钓鱼等功能

    绿色qq炫舞记忆助手 3.1.7-V0528B心动版 [增加社区钓鱼等功能]下载 软件大小:1.79MB 软件语言:简体中文 软件类别: 软件授权:免费软件 下载次数:3 更新时间:2013-07-1 ...

最新文章

  1. 解决微信H5获取SDK授权报错提示errMsg: “config:fail,Error: 系统错误,错误码:63002,invalid signature [20200908 22:17:17][]“
  2. 2021 IDEA大会开启AI思想盛宴,用“创业精神”做科研
  3. 一个 MVC 框架以 MVVM 之「魂」复活了!
  4. php 数组 指针,php之数组指针详解
  5. optfine的jar文件打不开_JAVA版1.14.4 装了最新版的optifine游戏打不开了 求助大佬们...
  6. 《风暴英雄》里那些超棒的游戏设计
  7. mysql 一对多映射_mybatis关系映射之一对多和多对一
  8. Linux下screen的应用
  9. CF788789(div1div2)
  10. 【剑指offer】十九,数组中出现次数超过一半的数字
  11. 初识人工智能(一):数据分析(二):numpy科学计算基础库(一)
  12. ios获取新数据要不要关_iPhone用户注意!不要再滑动关后台,否则……
  13. eclipse导入github项目(踩多个坑后发现这个最实用)
  14. VUE2.0 测试环境配置
  15. LiveGBS国标获取接入海康大华宇视摄像机设备通道的视频流直播地址 HLS/HTTP-FLV/WS-FLV/WebRTC/RTMP/RTSP
  16. 深信服vmp云桌面安装测试小结
  17. 计算机组装训练知识总结,组装知识总结
  18. ftp服务器扫描不了文件内容,ftp服务器扫描不了文件
  19. NYOJ234吃土豆
  20. R语言分析股票指数的GARCH效应

热门文章

  1. 机器学习实践系列之2 - GPUImage
  2. linux下如何批量杀进程,Linux下如何批量Kill多个进程
  3. ios 内购正式环境_iOS 内购最新讲解
  4. ios内购二次验证安全性问题_iOS内购之二次验证
  5. 综合项目实战(电影购票系统)
  6. 活动推荐 | 听说 PHP 是最好的语言 - 和 OneAPM 一起参与上海 PHPCon 技术盛宴
  7. 最后的问题(阿西莫夫)中文翻译
  8. 镍氢电池怎么修复充电
  9. python进阶练习之——养兔子
  10. 时间工具类,根据本月时间获取上月一号零点零时零分零秒