HDU 2064 汉诺塔III(递归)

摘要:
大约在19世纪末,一种智力玩具在欧洲的商店里出售。一块铜板上有三根柱子,由64个圆盘组成的塔从上到下,从小到大串在最左边的柱子上。其目的是将最左端的所有磁盘移动到右极,前提是一次只能移动一个磁盘,并且不允许将大磁盘放在小磁盘上。现在我们改变游戏的玩法。不允许从最左(右)侧直接移动到最右(左)侧(每次移动都必须移动到中间极或从中间移出),也不允许将大圆盘放在下圆盘的顶部

题目链接

Problem Description
约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下、由小到大顺序串着由64个圆盘构成的塔。目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动一个盘,且不允许大盘放在小盘的上面。
现在我们改变游戏的玩法,不允许直接从最左(右)边移到最右(左)边(每次移动一定是移到中间杆或从中间移出),也不允许大盘放到下盘的上面。
Daisy已经做过原来的汉诺塔问题和汉诺塔II,但碰到这个问题时,她想了很久都不能解决,现在请你帮助她。现在有N个圆盘,她至少多少次移动才能把这些圆盘从最左边移到最右边?
 
Input
包含多组数据,每次输入一个N值(1<=N=35)。
 
Output
对于每组数据,输出移动最小的次数。
 
Sample Input
1
3
12
 
Sample Output
2
26
531440
 
题解:递归理解,先将n-1个盘从左移到中间再到右,将第n个盘移到中间,然后前n-1个盘移到中间再到左,再将第n个盘移动到右,最后前n-1个盘移到中间再到右。也就是说前n-1个盘要移动三次,第n个盘要移动两次,所以f(n)=3*f(n-1)+2,当n==1的时候,返回2.
 
#include <cstdio>
#include <iostream>
#include <string>
#include <sstream>
#include <cstring>
#include <stack>
#include <queue>
#include <algorithm>
#include <cmath>
#include <map>
#define PI 3.1415926
#define ms(a) memset(a,0,sizeof(a))
#define msp memset(mp,0,sizeof(mp))
#define msv memset(vis,0,sizeof(vis))
using namespace std;
//#define LOCAL
int a[100005],b[100005];
long long fun(int n)
{
    if(n==1)return 2;
    return 3*fun(n-1)+2;
}
int main()
{
#ifdef LOCAL
    freopen("in.txt", "r", stdin);
#endif // LOCAL
    //Start
    int n;
    while(cin>>n)
    {
        long long ans=fun(n);
        printf("%I64d
",ans);
    }
    return 0;
}
 

免责声明:文章转载自《HDU 2064 汉诺塔III(递归)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇给el-table-column添加指定列的点击事件Jmeter(十)将结果树中的结果保存到本地下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

assert用法

assert宏的原型定义在<assert.h>中,其作用是如果它的条件返回错误,则终止程序执行,原型定义: void assert( int expression ); assert的作用是计算表达式 expression ,如果其值为假(即为0),那么它先向stderr打印一条出错信息,然后通过调用 abort 来终止程序运行。看下面的程序:...

c++消息队列的实现

#ifndef NET_FRAME_CONCURRENT_QUEUE_H #define NET_FRAME_CONCURRENT_QUEUE_H #include <queue> #include <mutex> #include <condition_variable> template<cla...

SQL Server 通过“with as”方法查询树型结构

一、with as 公用表表达式   类似VIEW,但是不并没有创建对象,WITH  AS 公用表表达式不创建对象,只能被后随的SELECT语句,其作用:   1. 实现递归查询(树形结构)   2. 可以在一个语句中多次引用公用表表达式,使其更加简洁 二、非递归的公共表达式   可以是定义列或自动列和select into 效果差不多 --指定列 wi...

树形DP+RMQ+单调队列(Bob’s Race HDU4123)

题意:有n个房子,这些房子被n-1条道路连接,有一些运动员从一个房子为起点尽可能跑最远的距离且不能通过一条道路超过两次,这些运行员不能选择同样的起点,这些运动员跑的最远距离和最近距离的差值不能超过Q,这些运行员的起点房间编号都是连续的,问最多可以选择多少个运动员跑步? 分析:就是给出一颗树形图,先用dp求出每个点所能经过的最远距离,然后用rmq求区间最值,...

Opencv 图片边缘检测和最小外接矩形

1 #include "core/core.hpp" 2 #include "highgui/highgui.hpp" 3 #include "imgproc/imgproc.hpp" 4 #include "iostream" 5 #include "cmath" 6 using namespacestd; 7 using namespacecv; 8...

【视频开发】【Live555】摄像头采集,264编码,live555直播(0)

参看 有关live555  1.首先需要修改live555,定义从 内存中直接获取source而不是从文件读取source的类。 自己实现的类命名为 H264FramedLiveSource    /* * Filename: H264FramedLiveSource.hh * Auther: chenbin * Create da...