codeforces392B
CF392B Tower of Hanoi
题意翻译
河内塔是一个众所周知的数学难题。它由三根杆和一些可以滑动到任何杆上的不同尺寸的圆盘组成。难题从一个整齐的杆中开始,按照尺寸从小到大的顺序排列,最小的位于顶部,从而形成一个圆锥形状。难题的目标是将整个杆移动到另一个杆,遵循以下简单规则:
- 一次只能移动一个圆盘。
- 每一步都是从其中一个杆取出上面的圆盘并将它放在另一个杆的顶部,即只有当圆盘是杆中最上面的圆盘时才能移动圆盘。
- 没有圆盘可能放置在较小的圆盘顶部。
有了三个圆盘,这个难题可以通过七个步骤解决。解决河内难题所需的最小移动次数是2^n - 1,其中n是圆盘的数量。 SmallY的难题非常类似于着名的河内塔。在河内之谜游戏中,你需要以最少的动作来解决难题,在SmallY的谜题中,每一个动作都需要花费一些钱,而且你需要解决同样的难题,但要花费最少。 在SmallY的难题开始时,所有的n个磁盘都在第一根杆上。将圆盘从杆i移动到杆j需要花费t[i,j]个金钱单位。(1 <= i,j <= 3).这个难题的目标是将所有的圆盘移动到第三个杆上。在这个问题中给出矩阵t和整数n。您需要计算解决SmallY难题的最小成本,其中包含n个圆盘。 输入输出格式输入格式:前三行中的每一行都包含三个整数 - 矩阵t。第i行第j个整数为t[i,j](1 <= t[ij] <= 10000; i≠j )。以下行包含一个整数n表示圆盘数量(1 <= n <= 40)。当i满足: (1 <= i <= 3), t[i,i] = 0. 输出格式:打印一个整数 - 解决SmallY难题的最低成本。
sol:dp[i][j][k]表示i个盘子,从j移到k,有两种方法,一种是传统的,另一种比较NB
例如从1到3 n个:1->2(n-1),1->3最大盘,2->3(n-1)
或者
1->3(n-1),1->2最大盘,3->1(n-1),2->3最大盘,1->3(n-1)
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
inline ll read()
{
ll s=; bool f=; char ch=' ';
while(!isdigit(ch)) {f|=(ch=='-'); ch=getchar();}
while(isdigit(ch)) {s=(s<<)+(s<<)+(ch^); ch=getchar();}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<) {putchar('-'); x=-x;}
if(x<) {putchar(x+''); return;}
write(x/); putchar((x%)+'');
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
int n;
ll tim[][],dp[][][];
int main()
{
// freopen("data.in","r",stdin);
int i,j,k;
memset(dp,,sizeof dp);
for(i=;i<=;i++)
{
for(j=;j<=;j++)
{
R(tim[i][j]); dp[][i][j]=;
}
}
R(n);
for(i=;i<=n;i++)
{
for(j=;j<=;j++) for(k=;k<=;k++) if(j!=k)
{
int oo=-j-k;
dp[i][j][k]=min(dp[i][j][k],dp[i-][j][oo]+tim[j][k]+dp[i-][oo][k]);
dp[i][j][k]=min(dp[i][j][k],dp[i][j][oo]+dp[i-][oo][j]+tim[oo][k]+dp[i-][j][k]);
dp[i][j][k]=min(dp[i][j][k],dp[i-][j][k]+tim[j][oo]+dp[i-][k][j]+tim[oo][k]+dp[i-][j][k]);
}
}
Wl(dp[n][][]);
return ;
}
codeforces392B的更多相关文章
随机推荐
- 普通表分区改造_rename方式
一.需求 配合开发人员,对业务临时表进行分区改造(业务认为的临时表,只需要保留近一月数据,并非oracle临时表类型) 二.如下记录完整过程 开发需求 TS_PM 以time_key分区 .沟通明确方 ...
- (二)CXF之用CXF官方工具生成客户端Client
一.CXF工具的下载与使用 登录CXF官网:http://cxf.apache.org/download.html 下载,本系列使用的是3.1.5版本: 添加path环境变量 二.案例 2.1 发布w ...
- java 框架-消息队列ActiveMQ
https://www.jianshu.com/p/ecdc6eab554c ActiveMQ从入门到精通(一) 22017.03.11 21:40:42字数 2650阅读 57286 这是关于消息中 ...
- 3d转化
3d转化 想要实现3d效果,首先要确定的是观察点,这是2d转换所不需要的.具体的我也看的很糊涂,美术什么的根本不懂好吗. 但有些东西是确定的,perspective定义的是3d元素距视图的距离,因此像 ...
- java - day010 - 基本类型包装,自动装箱和拆箱,日期,集合
基本类型的包装类 byte Byte short Short int Integer long Long float Float double Double char Character boolea ...
- COM_STMT_PREPARE 1
mysqld_stmt_prepare void mysqld_stmt_prepare(THD* thd, const char * query, uint length, Prepared_sta ...
- 09 Windows编程——键盘消息
焦点窗口:接收到这个键盘事件的窗口称为有输入焦点的窗口.具有输入焦点的窗口要么是活动窗口,要么是活动窗口的子孙窗口. 活动窗口:活动窗口通常是很好鉴别的.它总是最上层的窗口——也就是说,它的父窗口句柄 ...
- markdown编辑器抉择经历(做笔记\多系统用户)
之前一段时间,为了找到一款合适的md编辑器可谓是费尽了心思,用了我不少时间才找到一款合适的跨平台的又美观方便的编辑器----马克飞象. 感觉虽然有些编辑器功能很强大,对于使用性单一的用户,比如像我这种 ...
- No PostCSS Config found in报错解决
前情提要]日前本人将本地项目上传GitHub之后,然后再clone到本地,运行是报错:Error: No PostCSS Config found in... 项目在本地打包运行的时候不报错,上传到 ...
- Java字节码整体分析与总结
上一次[https://www.cnblogs.com/webor2006/p/9508341.html]已经将编译器生成的默认构造方法的字节相关的分析完了,接下来则分析咱们自定义的方法啦,按照顺序来 ...