CF392B Tower of Hanoi

题意翻译

河内塔是一个众所周知的数学难题。它由三根杆和一些可以滑动到任何杆上的不同尺寸的圆盘组成。难题从一个整齐的杆中开始,按照尺寸从小到大的顺序排列,最小的位于顶部,从而形成一个圆锥形状。难题的目标是将整个杆移动到另一个杆,遵循以下简单规则:

  1. 一次只能移动一个圆盘。
  2. 每一步都是从其中一个杆取出上面的圆盘并将它放在另一个杆的顶部,即只有当圆盘是杆中最上面的圆盘时才能移动圆盘。
  3. 没有圆盘可能放置在较小的圆盘顶部。

有了三个圆盘,这个难题可以通过七个步骤解决。解决河内难题所需的最小移动次数是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的更多相关文章

随机推荐

  1. IMPDPORA-27046,dump文件损坏

    客户提出导入报错 一.报错如下 SYMPTOMS DataPump Import (IMPDP) fails with the following errors: ORA-: invalid oper ...

  2. jacascript CSS样式的脚本化(js)操作

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 引入CSS有3种方式:行间样式,内联样式和外部链接样式. 在实际工作中,我们使用 javascript 操 ...

  3. (十一)springmvc和spring的整合

    1:Maven引入相关的jar包. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="ht ...

  4. 【SQL Server学习笔记】Delete 语句、Output 子句、Merge语句

    原文:[SQL Server学习笔记]Delete 语句.Output 子句.Merge语句 DELETE语句 --建表 select * into distribution from sys.obj ...

  5. Html Agility Pack 使用 XPath 选择器

    想做一个爬虫程序,以前用的一直使用CSS选择器的html解析插件,最近做的项目想使用 Html Agility Pack 来做解析 Html Agility Pack使用 XPath 和 Linq 来 ...

  6. SOLID Principles

    Intention: more understandable, easier to maintain and easier to extend.(通过良好的设计使得代码easy and simple, ...

  7. Python练习_考试第二次

    一. 选择题(32分) 1. python不支持的数据类型有:AA. charB. intC. floatD. list 2. Ex = ‘foo’y = 2print(x + y)A. fooB. ...

  8. S2-029

    前言 S2-029漏洞是由于Struts2的i18n.text标签中的name属性的值会经过两次Ognl表达式解析. 正文 假设有如下缺陷代码: jsp文件中使用Struts2的i18n标签获取请求中 ...

  9. 【Hibernate】抓取策略

    一.区分延迟和立即检索 二.类级别检索和关联级别检索 一.区分延迟和立即检索 立即检索: 当执行某行代码的时候,马上发出SQL语句进行查询. get() 延迟检索: 当执行某行代码的时候,不会马上发出 ...

  10. oracle 的普通语法

    select sysdate from dual -- 时间 select SYS_GUID() from dual --唯一