【题目链接】:http://www.lydsy.com/JudgeOnline/problem.php?id=1019

【题意】

【题解】



这个题解讲得很清楚了

http://blog.sina.com.cn/s/blog_76f6777d0101b8l1.html

大概就是设

f[i][j],g[i][j]分别表示第i个塔上有j个盘,然后这j个盘全部转移到g[i][j]上的方案数;

f[1..3][1]和g[1..3][1]都能根据一开始那个东西确定.

第i个塔有n个盘

则n-1个移到一个上

然后剩一个大的放在另外一个上面;

然后再把它们合在一起就能整体移出去了

(对一个盘只能操作一次,不,应该说不能对一个盘连续操作,n-1个盘看成整体一个盘);

根据汉诺塔的移动规则写递推.

最后输出f[1][n]

我把分析摘录下来。

都是上面那个博客的.

  1. /*
  2. f[x][i],g[x][i] 可由 f[][i-1],g[][i-1] 推得:
  3. 汉诺塔的经典转移,先做子问题把x柱上的i-1个圆盘移走,再把第i个大圆盘移走..
  4. 若设y=g[x][i-1],z=1+2+3-y-x(即除x,y以外的柱子编号)
  5. 即1) x上i-1个圆盘移至y上
  6. 2)由于不能对一个圆盘进行重复操作,所以必是将x上的第i个圆盘,移至z
  7. 由于i个圆盘还没叠到一起,所以接下来显然还要再次移动y上的i-1个,这时需要分类讨论:
  8. 若 f[y][i-1]=z:
  9. 3)移到z后,便结束了
  10. 综合以上,这种情况下,f[x][i]=f[x][i-1]+1+f[y][i-1],g[x][i]=z
  11. 若f[y][i-1]=x:
  12. 3)i-1个圆盘移至x
  13. 4)不能对一个圆盘进行重复操作,所以必将z上的第i个圆盘,移至y
  14. 5)因g[x][i-1]=y,所以x上i-1个圆盘移至y,结束
  15. 综合以上,这种情况下,f[x][i]=f[x][i-1]+1+f[y][i-1]+1+f[x][i-1],g[x][i]=y
  16. */

ps:这题还能构造线性关系搞



f[n] = k*f[n-1]+b;

求出k和b就能搞;

当然要从n>=3开始.



【完整代码】

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. #define lson l,m,rt<<1
  4. #define rson m+1,r,rt<<1|1
  5. #define LL long long
  6. #define rep1(i,a,b) for (int i = a;i <= b;i++)
  7. #define rep2(i,a,b) for (int i = a;i >= b;i--)
  8. #define mp make_pair
  9. #define pb push_back
  10. #define fi first
  11. #define se second
  12. #define rei(x) scanf("%d",&x)
  13. #define rel(x) scanf("%lld",&x)
  14. typedef pair<int, int> pii;
  15. typedef pair<LL, LL> pll;
  16. const int dx[9] = { 0,1,-1,0,0,-1,-1,1,1 };
  17. const int dy[9] = { 0,0,0,-1,1,-1,1,-1,1 };
  18. const double pi = acos(-1.0);
  19. const int N = 40;
  20. int n;
  21. char s[8][5];
  22. LL f[4][N];
  23. int g[4][N];
  24. int main()
  25. {
  26. //freopen("F:\\rush.txt", "r", stdin);
  27. rei(n);
  28. rep1(i, 1, 6)
  29. scanf("%s", s[i]);
  30. rep1(i, 1, 3)
  31. {
  32. rep1(j, 1, 6)
  33. {
  34. if (s[j][0] - 'A' + 1 == i)
  35. {
  36. g[i][1] = s[j][1] - 'A' + 1;
  37. f[i][1] = 1;
  38. break;
  39. }
  40. }
  41. }
  42. rep1(i, 2, n)
  43. {
  44. rep1(x, 1, 3)
  45. {
  46. int y = g[x][i - 1];
  47. int z = 1 + 2 + 3 - x - y;
  48. if (g[y][i - 1] == z)
  49. {
  50. f[x][i] = f[x][i - 1] + 1 + f[y][i - 1];
  51. g[x][i] = z;
  52. }
  53. else
  54. {
  55. f[x][i] = f[x][i - 1] + 1 + f[y][i - 1] + 1 + f[x][i - 1];
  56. g[x][i] = y;
  57. }
  58. }
  59. }
  60. printf("%lld\n", f[1][n]);
  61. return 0;
  62. }

【BZOJ 1019】 [SHOI2008]汉诺塔的更多相关文章

  1. BZOJ 1019: [SHOI2008]汉诺塔( dp )

    dp(x, y)表示第x根柱子上y个盘子移开后到哪根柱子以及花费步数..然后根据汉诺塔原理去转移... ------------------------------------------------ ...

  2. BZOJ 1019: [SHOI2008]汉诺塔

    Description 一个汉诺塔,给出了移动的优先顺序,问从A移到按照规则移到另一个柱子上的最少步数. 规则:小的在大的上面,每次不能移动上一次移动的,选择可行的优先级最高的. Sol DP. 倒着 ...

  3. BZOJ 1019 :[SHOI2008]汉诺塔(递推)

    好吧蒟蒻还是看题解的 其实看到汉诺塔就该想到是递推了 设f[i][j]表示i个在j杆转移到另一个杆的次数 g[i][j]表示i个在j杆转移到那个杆上 可得 f[i][j]=f[i-1][j]+1+f[ ...

  4. 【BZOJ 1019】 1019: [SHOI2008]汉诺塔 (DP?)

    1019: [SHOI2008]汉诺塔 Description 汉诺塔由三根柱子(分别用A B C表示)和n个大小互不相同的空心盘子组成.一开始n个盘子都摞在柱子A上,大的在下面,小的在上面,形成了一 ...

  5. 1019: [SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1495  Solved: 916[Submit][Status] ...

  6. 【BZOJ】1019: [SHOI2008]汉诺塔

    http://www.lydsy.com/JudgeOnline/problem.php?id=1019 题意:汉诺塔规则,只不过盘子n<=30,终点在B柱或C柱,每一次移动要遵守规则:1.小的 ...

  7. bzoj千题计划109:bzoj1019: [SHOI2008]汉诺塔

    http://www.lydsy.com/JudgeOnline/problem.php?id=1019 题目中问步骤数,没说最少 可以大胆猜测移动方案唯一 (真的是唯一但不会证) 设f[i][j] ...

  8. bzoj1019 [SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1030  Solved: 638[Submit][Status] ...

  9. 【bzoj1019】[SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1427  Solved: 872[Submit][Status] ...

  10. bzoj1019: [SHOI2008]汉诺塔(动态规划)

    1019: [SHOI2008]汉诺塔 题目:传送门 简要题意: 和经典的汉诺塔问题区别不大,但是题目规定了一个移动时的优先级: 如果当前要从A柱子移动,但是A到C的优先级比A到B的优先级大的话,那就 ...

随机推荐

  1. svd 奇异值分解

    参考:http://www.cnblogs.com/pinard/p/6251584.html 酉矩阵,关于矩阵的问题,还是很复杂的. 只有方阵才可以进行特征值分解, 但是如果行不等于列,即不是方阵, ...

  2. 【CS Round #46 (Div. 1.5) C】Set Subtraction

    [链接]h在这里写链接 [题意] 一开始有n个数字,然后有一个数字X,把每个数字都减去X,又生成N个新的数字. 然后把这2*N个数字混在一起. 告诉你这2*N个数字是什么.让你复原出原来的N个数字,以 ...

  3. 为什么要学习Numerical Analysis

    前几日我发了一个帖子,预告自己要研究一下  Numerical Analysis 非常多人问我为啥,我统一回答为AI-----人工智能 我在和教授聊天的时候,忽然到了语言发展上 我说:老S啊(和我关系 ...

  4. windows下安装emscripten

    windows下安装emscripten windows下安装emscripten需要python.git环境 python安装 git安装 开始安装 # 1.克隆emsdk git clone ht ...

  5. 扩展的方法:es6 安装模块builder

    https://github.com/es-shims/es5-shim/ Image.png 检测浏览器可支持es5,不支持就扩展,做兼容: 扩展的方法: Image.png 取所有对象的键值: o ...

  6. 原生js大总结一

    001.浅谈堆和栈的理解?   js变量存储有栈存储和堆存储,基本数据类型的变量存储在栈中,引用数据类型的变量存储在堆中 引用类型数据的地址也存在栈中   当访问基础类型变量时,直接从栈中取值.当访问 ...

  7. [React Intl] Use a react-intl Higher Order Component to format messages

    In some cases, you might need to pass a string from your intl messages.js file as a prop to a compon ...

  8. LDD3之并发和竞态-completion(完毕量)的学习和验证

    LDD3之并发和竞态-completion(完毕量)的学习和验证 首先说下測试环境: Linux2.6.32.2 Mini2440开发板 一開始难以理解书上的书面语言,这里<linux中同步样例 ...

  9. POJ 1979 Red and Black (zoj 2165) DFS

    传送门: poj:http://poj.org/problem?id=1979 zoj:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problem ...

  10. POJ 3211 Washing Clothes 0-1背包

    题目大意: xxx很懒,但他有个漂亮又勤奋的女友 (尼玛能不能不刺激我,刚看到这题的时候发现自己的衣服没洗!!!) 可以帮他洗衣服. 洗衣服的时候要求不同的颜色的衣服不能同时洗.一人洗一件的话,问最短 ...