博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
南阳理工acm 88-汉诺塔(一)
阅读量:4346 次
发布时间:2019-06-07

本文共 1055 字,大约阅读时间需要 3 分钟。

汉诺塔(一)

描述

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

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

输入
第一行是一个整数N表示测试数据的组数(0<N<20)

每组测试数据的第一行是一个整数m,表示起始时金片的个数。(0<m<1000000000)
输出
输出把金片起始针上全部移动到另外一个针上需要移动的最少步数的十进制表示的最后六位。
样例输入
2
1000
样例输出
1
69375
对于汉诺塔求移动次数公式为f(n+1)=f(n)*2+1;
此题如果用要求十进制最后六位,f(n+1)=(f(n)*2+1)%100000;
每次输入层数,求出移动次数,但如果输入数据很大,利用此公式必定超时,经过多次测试,发现若输入数据大于100005,有如下规律,如:
f(123456)=f(23456); f(123456789)=f(23456789)---=f(56789)
即略去最高位,
但 if(m%100000<6)则需进行此操作 m=100000+m;
这样就不会超时了
#include
int num[100006];int main(){ int N,m,i; num[1]=1; for(i=2;i<100006;i++) num[i]=(2*num[i-1]+1)%1000000; scanf("%d",&N); while(N--) { scanf("%d",&m); if(m>100005) { if(m%100000<6) m=100000+m%10; else m%=100000; } printf("%d\n",num[m]); } return 0;}

转载于:https://www.cnblogs.com/pcoda/archive/2011/07/18/2110022.html

你可能感兴趣的文章
CMU Bomblab 答案
查看>>
技术分析淘宝的超卖宝贝
查看>>
Azure云服务托管恶意软件
查看>>
My安卓知识6--关于把项目从androidstudio工程转成eclipse工程并导成jar包
查看>>
旧的起点(开园说明)
查看>>
生产订单“生产线别”带入生产入库单
查看>>
crontab导致磁盘空间满问题的解决
查看>>
自定义滚动条
查看>>
APP开发手记01(app与web的困惑)
查看>>
初识前端作业1
查看>>
ffmpeg格式转换命令
查看>>
万方数据知识平台 TFHpple +Xpath解析
查看>>
Hive实现oracle的Minus函数
查看>>
秒杀多线程第四篇 一个经典的多线程同步问题
查看>>
RocketMQ配置
查看>>
关于typedef的用法总结(转)
查看>>
Linux下安装rabbitmq
查看>>
【转】判断点在多边形内(matlab)
查看>>
excel第一次打开报错 向程序发送命令时出错 多种解决办法含终极解决方法
查看>>
机器码和字节码
查看>>