NYOJ 740 “炫舞家”ST
“炫舞家“ST
- 描述
-
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[i][j][k] 表示第 i 次踩踏后两脚的位置 j k
x=dp[i-1][k][j]+cost[k][a[i]]; 是通过k踩过来的,cost[k][a[i]]表示k->a[i]的花费
y=dp[i-1][j][k]+cost[k][a[i]]; 是通过k踩过来的,cost[k][a[i]]表示k->a[i]的花费
dp[i][j][a[i]]=dp[i][a[i]][j]=min(x,y)
结果为:ans=min(dp[n][j][a[i]])
#include<iostream>
#define INF 0x3f3f3f3f
using namespace std;
int a[10005],dp[10005][6][6],cost[6][6];
int main()
{int ans;int t,n,x,y;while(cin>>t){if(t==0) break;a[1]=t;for(n=2;;n++){cin>>a[n];if(!a[n]) break;}for(int i=0;i<5;i++)for(int j=0;j<5;j++)cost[i][j]=INF;cost[1][1]=cost[2][2]=cost[3][3]=cost[4][4]=1;cost[1][2]=cost[2][1]=cost[2][3]=cost[3][2]=cost[3][4]=cost[4][3]=cost[1][4]=cost[4][1]=3;cost[1][3]=cost[3][1]=cost[2][4]=cost[4][2]=4;cost[0][1]=cost[0][2]=cost[0][3]=cost[0][4]=2;for(int i=0;i<=n;i++)for(int j=0;j<5;j++)for(int k=0;k<5;k++)dp[i][j][k]=INF;dp[0][0][0]=0;ans=INF;for(int i=1;i<n;i++){for(int j=0;j<5;j++){if(j==a[i]) continue;x=y=INF;for(int k=0;k<5;k++){ //左脚踩 if(j!=k || j+k==0){if(x>dp[i-1][k][j]+cost[k][a[i]])x=dp[i-1][k][j]+cost[k][a[i]];}}for(int k=0;k<5;k++){ //右脚踩 if(j!=k || j+k==0){if(y>dp[i-1][j][k]+cost[k][a[i]])y=dp[i-1][j][k]+cost[k][a[i]];}}if(x>y) x=y;dp[i][j][a[i]]=dp[i][a[i]][j]=x;if(ans>dp[n-1][j][a[i]]) ans=dp[n-1][j][a[i]];}}cout<<ans<<endl;}return 0;
}
NYOJ 740 “炫舞家”ST相关推荐
- 题目 740 “炫舞家“ST
"炫舞家"ST 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...
- nyist 740 “炫舞家“ST
题目地址:http://acm.nyist.net/JudgeOnline/problem.php?pid=740 思路: #include <iostream> #include < ...
- NYOJ740 - “炫舞家“ST (DP)
题目链接 NYOJ740 [题意] "炫舞家"ST 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 ST是一个酷爱炫舞的玩家.T ...
- nyoj-740 “炫舞家“ST
"炫舞家"ST 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...
- nyoj740“炫舞家“ST【dp】
"炫舞家"ST 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...
- nyistOJ-“炫舞家“ST(DP)
"炫舞家"ST 时间限制: 3000 ms | 内存限制: 65535 KB 难度: 3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机 ...
- 90 后董事长的国内首个元宇宙婚礼!网友:不由得想起了 QQ 炫舞和飞车......
整理 | 郑丽媛 出品 | 程序人生(ID:coder_life) 在你的设想中,一场特别的婚礼应该是怎样的?拥有独一无二的主题,穿着打破陈规的服饰,还是举办在出其不意的地点? 10 月 8 日,国内 ...
- 中手游署理《每天炫舞》内测 前进精品手游商场
署理的以交际娱乐为主的舞蹈类手游<每天炫舞>将于4月18日在91帮手.安卓商场.baidu多酷.安智商场.当乐.UC.360.豌豆荚等多家渠道进行不删档内测,中国手游官网也供给游戏包供玩家 ...
- 【绿色qq炫舞记忆助手心动版】增加社区钓鱼等功能
绿色qq炫舞记忆助手 3.1.7-V0528B心动版 [增加社区钓鱼等功能]下载 软件大小:1.79MB 软件语言:简体中文 软件类别: 软件授权:免费软件 下载次数:3 更新时间:2013-07-1 ...
最新文章
- poj-1384 Piggy-Bank
- Spring Boot 配置文件 yml与properties
- Hashtable.ContainsKey跟Hashtable.Contains的区别
- 1、oracle数据库简介
- 简单粗暴 我再送一波教程资料,Vue、大数据、AI都有
- ssis合并连接链接键_在SSIS包中使用合并联接转换
- Android关机流程解析
- [wikioi]最长严格上升子序列
- GridView控件属性及应用(转载)
- 5.深入分布式缓存:从原理到实践 --- 从Memcached开始了解集中式缓存
- Swift开发教程--怎样设置状态栏的文字颜色
- python生成颜色数组
- 安装虚拟机时勾选增强型键盘驱动程序有什么用?(在软件安装或者升级时候没勾选怎么办)
- API day02 IO流
- Java 8 新特性|Collectors.joining() 详解
- 企业WiFi覆盖,解决覆盖四大难题
- 上海电力学院计算机院校区,上海电力学院有几个校区及校区地址 哪个校区最好...
- nodejs express搭建服务器(爬虫知乎精华帖,个人学习用)六 html
- JSON.stringify详解
- Android 高质量开发之崩溃优化,kotlin匿名内部类
热门文章
- Linux监控利器atop,安装,配置日志切割,网络监控netatop
- Linux 使用 atop 监控工具
- python自动化脚本开发是什么意思_python自动化脚本编写电脑回事
- 《白话机器学习的数学》基础知识梳理 基于python的代码实现
- H5页面iphone(苹果)手机点击输入框输入内容时页面自动放大
- PHPExcel的常用功能
- 嵌入式项目实战——基于QT的视频监控系统设计(一)
- 最高法院不予核准受暴杀佳耦女李彦死刑判决
- 我到底要选择一种什么样的生活方式,度过这一辈子呢:人生自由与职业发展方向(上)...
- 影豹R·ABT联名版亮相上海车展,专为年轻人打造的个性化改装之选