nyoj 740 “炫舞家“ST

“炫舞家“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
AC代码:


 1 #include<iostream>
2 #include<algorithm>
3 #include<cmath>
4 using namespace std;
5 const int N=10010;
6 const int M=0X7ffffff;
7 int foot[N],cost[6][6],dp[N][6][6];
8 void fun()
9 {
10 for(int i=0;i<5;i++) for(int j=0;j<5;j++) cost[i][j]=M;//其他的花费,初始化为最大
11 cost[0][1]=cost[0][2]=cost[0][3]=cost[0][4]=2;
12 cost[1][2]=cost[2][1]=cost[2][3]=cost[3][2]=cost[3][4]=cost[4][3]=cost[4][1]=cost[1][4]=3;
13 cost[1][3]=cost[3][1]=cost[2][4]=cost[4][2]=4;
14 cost[1][1]=cost[2][2]=cost[3][3]=cost[4][4]=1;
15 }
16 int main()
17 {
18 int k,x,i,j,ans,y,n;
19 fun();
20 while(1)
21 { ans=0;
22 for( i=1; i<N; i++)
23 {
24 cin>>x;
25 if(x==0)
26 break;
27 else foot[i]=x;
28 }
29 n=i;
30 if(i==1)
31 break;
32 else
33 {
34 for(i=0;i<=n;i++)
35 for(j=0;j<5;j++)
36 for(k=0;k<5;k++)
37 dp[i][j][k]=M; //全部初始化为最大的值;
38 dp[0][0][0]=0; ans=M;
39 for(i=1;i<n;i++) //表示的是步数;
40 {
41 for(j=0;j<5;j++) //没动的脚
42 {
43 if(j==foot[i]) continue; //当前位置上有了一个脚;
44 x=y=M;
45 for(k=0;k<5;k++) //左脚踩这个点;
46 {
47 if(k!=j || k+j==0)
48 x=min(x,dp[i-1][k][j]+cost[k][foot[i]]);
49 }
50 for(k=0;k<5;k++) //右脚踩这个点;
51 {
52 if(k!=j||k+j==0)
53 y=min(y,dp[i-1][j][k]+cost[k][foot[i]]);
54 }
55 dp[i][j][foot[i]]=dp[i][foot[i]][j]=min(x,y);
56 ans=min(ans,dp[n-1][j][foot[i]]);//每次都寻找最小值
57 }
58 }
59 cout<<ans<<endl;
60 }
61 }
62 return 0;
63 }



时间: 2024-10-15 20:17:46

nyoj 740 “炫舞家“ST的相关文章

NYOJ 740 DP

“炫舞家“ST 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机(Dance Dance Revolution,DDR).但是TA每天还要努力的学习,因此TA希望每次都保存最多的体力来学习. DDR的主要内容是用脚来踩踏板.踏板有4个方向的箭头,用1,2,3,4来代表,如下图所示. 游戏规则如下:   每首歌曲有一个箭头序列,游戏者必须按照这个序列依次用某一只脚踩相应的踏板.在任何时候,

微信游戏《全民炫舞》公司的引擎开发和布料系统技术介绍

微信<全民炫舞>上线了. 整理了一下过去技术开发历史,还有技术ppt,有兴趣看下: 公司游戏引擎技术介绍: http://www.h3d.com.cn/hr/hr.htm 布料系统技术介绍: 2012 China Game Developer Conference大会演讲资料下载: http://www.h3d.com.cn/hr/downlond/QQX52_CGDC.ppt NVIDIA QQ炫舞2 布料技术演示录像地址: http://www.h3d.com.cn/hr/donnlond

天天炫舞特色花园

天天炫舞岛主花园在登陆游戏后的舞魅岛左边位置,在这里面可以种植各种奇花异草,当成功收获自己种植的鲜花后,并将其送给自己喜欢的人或者朋友会获得他们的称赞哦,因为你送的鲜花会给他们带来福利哦,比如说在商场购买商品会打折,在魅力排行榜获得奖励等等,总之你和朋友们互赠获得的越多,好处也就越多,这里就不一一说明了,自己亲自体验吧! (温馨提示:种植鲜花的材料可以在抽奖或者游戏中获得哦.) 下载优亿市场手游助手,了解更多关于手机游戏的最新玩法,还有海量的手机APP应用等你下载使用.

海南哪里有厂家批发爆款智能故事遥控机器人劲风太空跳舞炫舞玩具批发???汕头市仁捷玩具有限公司

汕头市仁捷玩具有限公司 134-1712-7372本厂玩具类型有:电动.益智.早教.智能.机器人.发光.音乐.新奇特.赠品.新款.地摊.讲故事.儿童.男孩.女孩.义乌临沂澄海玩具批发....等等其他.出厂超低批发价.保证质量 汕头市仁捷玩具有限公司 134-1712-7372 专注:厂家直销劲风机器人炫舞机器人跳舞机器人智能故事机器人芭比娃娃炫舞玩具"汇聚力量,创造辉煌!" 本公司位于集海陆空交通便利的中国玩具之城-广东省汕头市澄海区,专业玩具生产及销售各种中高低档的玩具产品和工艺礼品

QQ炫舞官网选项卡效果

这篇博文里需要注意的是当点击事件发生的时候,需要用循环,重置标题的classname和标题底部都设置成隐藏,当点击的时候在加上标题的active属性和显示属性 代码地址:https://github.com/peng666/blogs/tree/gh-pages/tab 在线测试地址:http://peng666.github.io/blogs/tab/

心舞折扣端体验原来炫舞也可以快速称王

“心舞”是一种集育人元素.多元化穿衣.多种玩法为一体的音乐舞蹈社交游戏.采用三维全视图自由开放游戏模式的目的是提高游戏的自由度,丰富玩家之间的互动游戏方式.游戏的整体艺术风格趋向于新鲜的二次动画风格,给玩家一个舒适的视觉体验.同时,音乐舞蹈演奏的核心方法也在核心技术上取得了突破,增加了多种演奏方式. <心舞>一款主打社交甜蜜的音乐舞蹈游戏,里面的画风好看,免费的衣服很好看,那种光效衣服活动做任务也能免费得到一些,也可以充值用钻去买,现在游戏刚开没多久衣服不算也多,以后肯定会越来越多的.如果你也

11-st跳舞消耗体力最少

/*                                                   炫舞家 ST 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述    ST是一个酷爱炫舞的玩家.TA很喜欢玩QQ炫舞,因此TA也爱屋及乌的喜欢玩跳舞机(Dance Dance Revolution,DDR).但是TA每天还要努力的学习,因此TA希望每次都保存最多的体力来学习. DDR的主要内容是用脚来踩踏板.踏板有4个方向的箭头,用1,2,3,4来代表,如下图所示

脱星摘帽刺激 ST板块表现出众

年报及业绩预告不断公布,在脱星摘帽.资产重组等一系列利好的刺激下,ST板表现出众.随着上市公司2015年财报披露的推进,*ST公司的命运也将浮出水面,近日多家有望“摘帽”的公司大多都走出了不错的行情,再度引发市场对“摘帽”概念股的追捧,由此也引发st板块走出拉升行情,预计在未来一段时间内,这样的行情都将持续. ST板块表现活跃 随着年报及业绩预告不断公布,在脱星摘帽.资产重组等一系列利好的刺激下,ST板块表现出众.昨天*ST中富(000659).*ST星美(000892).*ST厦华(60087

大四到毕业到现在的一年时间

从去年下半年离校到今年六月份毕业到现在,差不多一年多的时间,这一年,有太多太多想说的,也不是说自己矫情,平时也没什么朋友,都憋在心里,也许说了也不理解那种心情,有时更多的是什么都不想说. 去年下半年的这个时候,毕业设计都弄完了,也答辩完了,得离校自己出来找工作了.当时,那个时候其实也很迷茫,很浮躁,因为大学四年就这么过了,自己学到了什么,作为一名计算机专业的学生真的现在想想,真的大学浪费了,多么好的四年时间,多么好的资源,没能好好确定一定目标,去努力.大一的时候去学校,高中毕业刚出来,啥都不懂,