zoukankan      html  css  js  c++  java
  • 汉诺塔

     

    汉诺塔(一)

    描述

    在印度,有这么一个古老的传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针。印度教的主神梵天在创造世界的时候,在其中一根针上从下到上地穿好了由大到小的64片金片,这就是所谓的汉诺塔。不论白天黑夜,总有一个僧侣在按照下面的法则移动这些金片:一次只移动一片,不管在哪根针上,小片必须在大片上面。僧侣们预言,当所有的金片都从梵天穿好的那根针上移到另外一根针上时,世界就将在一声霹雳中消灭,而梵塔、庙宇和众生也都将同归于尽。

    现在请你计算出起始有m个金片的汉诺塔金片全部移动到另外一个针上时需要移动的最少步数是多少?(由于结果太大,现在只要求你算出结果的十进制位最后六位)

     
    输入
    第一行是一个整数N表示测试数据的组数(0<N<20)
    每组测试数据的第一行是一个整数m,表示起始时金片的个数。(0<m<1000000000)
    输出
    输出把金片起始针上全部移动到另外一个针上需要移动的最少步数的十进制表示的最后六位
    样例输入
    2
    1
    1000
    样例输出
    1
    69375
    题解:快速幂,2的N次方;
    代码:
     1 #include<stdio.h>
     2 const int MAXN=1000000;
     3 int quit(long long k,int n){
     4     long long s=1;
     5     while(n){
     6         if(n&1)s*=k,s%=MAXN;
     7         n>>=1;
     8         k*=k;
     9         k%=MAXN;
    10     }
    11     return s;
    12 }
    13 int main(){
    14     int T,N;
    15     scanf("%d",&T);
    16     while(T--){
    17         scanf("%d",&N);
    18         printf("%d
    ",quit(2,N)-1);
    19     }
    20     return 0;
    21 }
  • 相关阅读:
    ZJU_1145 OR POJ_1100 Dreisam Equations
    数据结构基础之队列
    The New Villa
    Mission Impossible 6
    数据结构基础之栈
    POJ_1185_炮兵阵地 dp+状态压缩
    (转载)Dig命令的用法
    (转载)服务发现系统etcd介绍
    golang 导入包
    1.4方程求根之弦截法
  • 原文地址:https://www.cnblogs.com/handsomecui/p/4835715.html
Copyright © 2011-2022 走看看