题目描述                     Description

给定A、B、C三根足够长的细柱,在A柱上放有2n个中间有孔的圆盘,共有n个不同的尺寸,每个尺寸都有两个相同的圆盘,注意这两个圆盘是不加区分的(下图为n=3的情形)。现要将这些圆盘移到C柱上,在移动过程中可放在B柱上暂存。要求:

(1)每次只能移动一个圆盘;

(2)A、B、C三根细柱上的圆盘都要保持上小下大的顺序;

任务:设An为2n个圆盘完成上述任务所需的最少移动次数,对于输入的n,输出An

输入描述                 Input Description              

为一个正整数n,表示在A柱上放有2n个圆盘。

                输出描述                 Output Description              

仅一行,包含一个正整数, 为完成上述任务所需的最少移动次数An

                样例输入                 Sample Input              

2

样例输出                 Sample Output              

6

数据范围及提示                 Data Size & Hint              

对于50%的数据,1<=n<=25

对于100%的数据,1<=n<=200

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath> using namespace std; int n;
int an[],l;
int bn[];
int cn[]; void add()
{
memset(bn,,sizeof(bn));
int i,j;
for(i = ;i<=l;i++)
{
bn[i+] = (an[i]+an[i]+bn[i])/;
an[i] = (an[i]+an[i]+bn[i])%;
}
if(an[l] != ) l++;
}
void add2()
{
memset(bn,,sizeof(bn));
memset(cn,,sizeof(cn));
bn[] = ;
int i,j;
for(i = ;i<=l;i++)
{
cn[i+] = (an[i]+bn[i]+cn[i])/;
an[i] = (an[i]+bn[i]+cn[i])%;
}
if(an[l]) l++;
} int main()
{
int i,j,k;
int n;
memset(an,,sizeof(an));
an[] = ,l = ;
cin>>n;
for(i = ;i<=n;i++)
{
add();
add2();
}
add();
for(i = l-;i>=;i--)
printf("%d",an[i]);
cout<<endl;
return ;
}

codevs1145的更多相关文章

随机推荐

  1. Ascll

    ascll - 概述 ASCII码(American Standard Code for Information Interchange, 美国标准信息交换码).   信息编码就是将表示信息的某种符号 ...

  2. Sql server中根据object的定义查找object

    SELECT OBJECT_NAME(object_id) FROM sys.sql_modulesWHERE definition LIKE '%keyword to search%' 或者 SEL ...

  3. Sql Server相关的性能计数器

    OS Memory and Paging 性能计数器: 1.Memory\Availability Mbytes   未使用的物理内存(非页面文件),通常情况下它应该大于100MB 2.Memory\ ...

  4. Mplayer ARM平台下交叉编译

    下载MPlayer http://www.mplayerhq.hu/design7/dload.html 编译环境 系统 : ubuntu 11.04 交叉编译器版本 : Sourcery G++ L ...

  5. PHP扩展开发之简单类开发

    接下来我们要用扩展的形式实现以下类(演示环境:linux.php-5.5.34-src) <?php class Person { private $_name; public function ...

  6. MongoDB安装说明

    1.去官网(https://www.mongodb.org/dr/fastdl.mongodb.org/win32/mongodb-win32-x86_64-3.2.3-signed.msi/down ...

  7. 设计师如何为 Android 应用标注尺寸

    http://blog.cutterman.cn/?p=33 1. 画布大小定位 720 x 1280,72 dpi2. 只使用偶数单位的尺寸,比如 96 px 的列表项高度,16 px 的边距,64 ...

  8. python核心编程-第五章-个人笔记

    1.用del删除对对象的引用 >>> a = 123 >>> a 123 >>> del a >>> a Traceback ( ...

  9. PHP配置xdebug

    其实已经做PHP超过2年了,但是今天特别有感触,所以把过程写在这里 环境是win7+apache2.2+php5.3,因为某种原因,必须使用这个版本. 然后就死活配置不出来.apache日志如下: [ ...

  10. android 管理Bitmap内存 - 开发文档翻译

    由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没有注明“转”,那么均为原创,转贴请注明本博客链接链接   Managing Bitmap Memory 管理Bitmap内存 In additi ...