一.        题意:

算出汉诺塔移动序列中对应位置的号码,数据规模很大,所以不能单纯递归,而是要找出汉诺塔序列的规律。

二.        汉诺塔数列

为了得出最少的移动步数,当n为偶数时,最上层小盘子首先移动到过渡柱上;当n为奇数时,最上层小盘子首先移动到目标柱上。不论n为奇偶,过渡柱和目标柱上,盘子的叠加编号始终是奇偶叠加,不会出现奇数或偶数连续叠加。

这里的规律是:

第 n 项 = n 能被 2 整除的次数 + 1。 (需要用高精度)

汉诺塔数列例子:

盘子个数

数列

至少需要步数

N = 1

1

21-1=1

N = 2

121

22-1=3

N = 3

1213121

23-1=7

N = 4

121312141213121

24-1=15

操作步骤:

当n=1时:将盘子从A柱直接移到C柱,完成移动,即(A→C)。当n=2时:先把n-1=1个盘子从A柱移动到B柱,再将A柱上最后一个盘子从A柱移动到C柱,最后将B柱上的n—1个盘子从B柱移动到C柱上,完成移动,即A→B,A→C,B→C。

当n=3时:先把n-1=2个盘子从A柱移动到B柱(借助C),再将B柱上剩余的盘子移动到C柱(借助A)。

当n为任意正整数时:同样是先把n-1个盘子从A柱移动到B柱(借助C),方法与上述相同。

通过以上分析,Hanoi问题是典型的利用递归来解决的,是将规模为n的问题,降解为规模为n-1的小问题、n-2的较小问题……依次降解,直到递归出口,求出最低阶规模的解,代入高一阶问题中,直至求出规模为n的问题的解。递归包括回溯和递推两个过程。

为了分辨n个不同的盘子,将其由小到大依序编号为1,2,3,…,n-1,n,以便于研究其所需的移动次数及次序、探求其规则性。

从n=1、n=2的移动情况,可归纳出一个结论:即n=2时处理n=1两次,共须移动22-1=3步,其Hanoi数列为121。同理可知n=3时,处理n=2两次,共须移动23-1=7步,其Hanoi数列为1213121,同理可知n=4时,处理n=3两次,总共须移动24-1=15步,其汉诺塔数列为121312141213121,依此类推。

分析得出递归模型:

f(1)=1(n=1)

f(n)=2×f(n-1)+1(n>1→)

f(n)=2×f(n-1)+1

=2×(2×f(n-2)+1)+1

=2×(2×(2×f(n-3)+1)+1)+1……

=2n-1。

因此,n个盘子总共需移动最少步数计算公式为:f(n)=2n-1。

很容易看出对于n个盘子的汉诺塔的移动步骤为s(n+1)=s(n)(n+1)s(n),假设输入为p。则L(n)=2^n-1,L(n)表示n个盘子的汉诺塔的移动步骤的数目。假如p=2^n,则结果是n+1;否则可找出一个最小的n,使得p<=2^n-1。并且p>2^(n-1),否则p<=2^(n-1),由对称性知f(p)=f(p-2^(n-1)),即减去不超过P的2的最大次幂,这样一直减下去直至p=2^x.所以结果为最初始的p表示为2进制数后从右边数起的0的个数加1.

三.        代码

  1. //
  2. // main.cpp
  3. // sicily-1028
  4. //
  5. // Created by ashley on 14-11-7.
  6. // Copyright (c) 2014年 ashley. All rights reserved.
  7. //
  8.  
  9. #include <iostream>
  10. #include <string>
  11. using namespace std;
  12.  
  13. int counting(string data)
  14. {
  15. int sum = ;
  16. int length = (int)data.length();
  17. for (int i = ; i < length; i++) {
  18. data[i] = data[i] - '';
  19. }
  20. while (data[length - ] % == ) {
  21. for (int i = ; i < length; i++) {
  22. if (i + < length) {
  23. int b = data[i + ];
  24. data[i + ] = (data[i] % ) * + b;
  25. }
  26. data[i] = data[i] / ;
  27. }
  28. sum++;
  29. }
  30. return sum + ;
  31. }
  32.  
  33. int main(int argc, const char * argv[])
  34. {
  35. int cases;
  36. string number;
  37. cin >> cases;
  38. int counter = ;
  39. while (counter != cases) {
  40. cin >> number;
  41. counter++;
  42. cout << "Case " << counter << ": " << counting(number) << endl;
  43. if (counter < cases) {
  44. cout << endl;
  45. }
  46. }
  47. return ;
  48. }

Sicily-1028的更多相关文章

  1. sicily 中缀表达式转后缀表达式

    题目描述 将中缀表达式(infix expression)转换为后缀表达式(postfix expression).假设中缀表达式中的操作数均以单个英文字母表示,且其中只包含左括号'(',右括号‘)’ ...

  2. 【JSOI2007】麻将 bzoj 1028

    Description 麻 将是中国传统的娱乐工具之一.麻将牌的牌可以分为字牌(共有东.南.西.北.中.发.白七种)和序数牌(分为条子.饼子.万子三种花色,每种花色各有一到 九的九种牌),每种牌各四张 ...

  3. sicily 1934. 移动小球

    Description 你有一些小球,从左到右依次编号为1,2,3,...,n. 你可以执行两种指令(1或者2).其中, 1 X Y表示把小球X移动到小球Y的左边, 2 X Y表示把小球X移动到小球Y ...

  4. Light OJ 1028 - Trailing Zeroes (I) (数学-因子个数)

    题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1028 题目大意:n除了1有多少个因子(包括他本身) 解题思路:对于n的每个因子 ...

  5. hdu acm 1028 数字拆分Ignatius and the Princess III

    Ignatius and the Princess III Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K ...

  6. poj 1028

    http://poj.org/problem?id=1028 题意(水):做一个游览器的历史记录. back:后退到上一个页面,当上一个页面没有时,输出ignored. forward:向前一个页面, ...

  7. ACM: HDU 1028 Ignatius and the Princess III-DP

     HDU 1028 Ignatius and the Princess III Time Limit:1000MS     Memory Limit:32768KB     64bit IO Form ...

  8. hdu 1028 Ignatius and the Princess III 简单dp

    题目链接:hdu 1028 Ignatius and the Princess III 题意:对于给定的n,问有多少种组成方式 思路:dp[i][j],i表示要求的数,j表示组成i的最大值,最后答案是 ...

  9. NBUT 1028 该减肥了(简单递推)

    [1028] 该减肥了 时间限制: 1000 ms 内存限制: 65535 K 问题描述 由于长期缺乏运动,Teacher Xuan发现自己的身材臃肿了许多,于是他想健身,更准确地说是减肥.Teach ...

  10. PAT乙级 1028. 人口普查(20)

    1028. 人口普查(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 某城镇进行人口普查,得到了全体居民的 ...

随机推荐

  1. mysql之数据库特性认识

    最近面试经常被面试官问道关于数据库方面的知识,于是总结一下面试官问的题以及自己对数据库的认识 1.之前百度面试官问了我一个特别基础的sql问题:如何清除表的所有记录,以前在学校做项目开发的时候有使用过 ...

  2. 新视野OJ 2705 [SDOI2012]Longge的问题 (数论)

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2705 题解:求 sigma(gcd(i,n), 1<=i<=n<2^32) ...

  3. classpath的总结

    转自:http://blog.csdn.net/javaloveiphone/article/details/51994268   版权声明:本文为博主原创文章,未经博主允许不得转载. 1.src不是 ...

  4. nodejs事件机制

    var EventEmitter = function() { this.evts = {}; }; EventEmitter.prototype = { constructor: EventEmit ...

  5. SQL2-子查询、join查询

    SQL常用高级查询包括:Join查询.子查询. 子查询: USE flowershopdb --子查询:在一个select语句使用另一个select 语句作为条件或数据来源. --查询块:一个sele ...

  6. JSTL与EL常用标签(转)

    JSTL与EL EL相关概念 JSTL一般要配合EL表达式一起使用,来实现在jsp中不出现java代码段.所以我们先来学习EL表达式 EL主要用于查找作用域中的数据,然后对它们执行简单操作:它不是编程 ...

  7. TCP的阻塞和重传

    TCP的阻塞和重传 TCP的阻塞和重传机制 网络拥堵 现在网络上大部分的网络请求都是以TCP的方式进行传输的了.网络链路是固定的,各种链路情况也是不一样的.网络拥堵一直是TCP协议设计和使用的时候尽力 ...

  8. MySQL 关闭子表的外键约束检察

    准备: 定义一个教师表.一个学生表:在学生表中引用教师表ID create table teachers(teacherID int not null auto_increment primary k ...

  9. 在PADS LAYOUT中如何隐藏不需要的鼠线?

    如下图示,将net GPR_0的鼠线隐藏. 鼠标右键,选择网络----选择你要隐藏的网络------右键选择view nets----点击对话框右边View List里你所选的网络-----在右下角t ...

  10. qemu/kvm/qemu-kvm/virsh的区别

    转自:http://www.2cto.com/os/201305/209596.html qemu/kvm/qemu-kvm/virsh的区别   qemu是一套虚拟机管理系统,kqemu是qemu的 ...