题目描述

九连环是一种源于中国的传统智力游戏。如图所示,九个圆环套在一把“剑”上,并且互相牵连。游戏的目标是把九个圆环从“剑”上卸下。

圆环的装卸需要遵守两个规则。

第一个(最右边)环任何时候都可以装上或卸下。

如果第k个环没有被卸下,且第k个环右边的所有环都被卸下,则第k+1个环(第k个环左边相邻的环)可以任意装上或卸下。

与魔方的千变万化不同,解九连环的最优策略是唯一的。为简单起见,我们以“四连环”为例,演示这一过程。这里用1表示环在“剑”上,0表示环已经卸下。

初始状态为1111,每部的操作如下:

1101(根据规则2,卸下第2个环)

1100(根据规则1,卸下第1个环)

0100(根据规则2,卸下第4个环)

0101(根据规则1,装上第1个环)

0111(根据规则2,装上第2个环)

0110(根据规则1,卸下第1个环)

0010(根据规则2,卸下第3个环)

0011(根据规则1,装上第1个环)

0001(根据规则2,卸下第2个环)

0000(根据规则1,卸下第1个环)

由此可见,卸下“四连环”至少需要10步。随着环数增加,需要的步数也会随之增多。例如卸下九连环,就至少需要341步。

请你计算,有n个环的情况下,按照规则,全部卸下至少需要多少步。

输入

输入第一行为一个整数m ,表示测试点数目。

接下来m行,每行一个整数n。

输出

输出共m行,对应每个测试点的计算结果。

样例输入

3

3

5

9

样例输出

5

21

341

提示

对于10%的数据,1≤n≤10。

对于30%的数据,1≤n≤30。

对于100%的数据,1≤n≤105,1≤m≤10。

容易通过题目推出:

000000001 一环 1次

000000011 两环 2次

000000111 三环 5次

000001111 四环 10次

000011111 五环 21次

000111111 六环 42次

001111111 七环 85次

011111111 八环 170次

111111111 九环 341次

可根据两两差值得到规律,当为奇数环时,用的次数是上次的两倍+1次

当为偶数环时,是上一步次数的两倍

因此大体上可以确定次数和环数的关系应该是2^n

但有一个奇数差1的值影响

再次观察次数差值的差值

一环 1次—–>2^0+0———->2^0

两环 2次—–>2^1————->2^1

三环 5次—–>2^2+1———->2^0+2^2

四环 10次—–>2^3+2——–>2^1+2^3

五环 21次—–>2^4+5——–>2^0+2^2+2^4

六环 42次—–>2^5+10——>2^1+2^3+2^5

七环 85次—–>2^6+21——>2^0+2^2+2^4+2^6

八环 170次—–>2^7+42—->2^1+2^3+2^5+2^7

九环 341次—–>2^8+85—->2^0+2^2+2^4+2^6+2^8

可以看出,奇数环时的结果为公比为2^2,首项为2^0的等比数列求和

偶数环时的结果为公比为2^2,首项为2^1的等比数列求和

Sn=A1*(1-q^n)/(1-q)

因此直接用等比数列求和公式即可计算出答案,因为没有取模操作,要用Java高精度写比较方便

import java.util.*;

import java.math.*;

import java.io.*;

import java.net.*;

import java.io.*;

public class Main

{

public static void main(String args[])

{

Scanner scanf = new Scanner(System.in);

int t=scanf.nextInt();

BigInteger one=BigInteger.valueOf(1);

BigInteger three = BigInteger.valueOf(3);

while(t-->0)

{

int n=scanf.nextInt();

BigInteger sum=BigInteger.valueOf(1);

if((n&1)==1)

{

int tmp=(n+1)/2;

BigInteger four=BigInteger.valueOf(4);

while(tmp!=0)

{

if((tmp&1)==1)sum=sum.multiply(four);

four=four.multiply(four);

tmp>>=1;

}

sum=sum.subtract(one);

sum=sum.divide(three);

}

else

{

sum=sum.add(one);

int tmp=n/2;

BigInteger four=BigInteger.valueOf(4);

while(tmp!=0)

{

if((tmp&1)==1)sum=sum.multiply(four);

four=four.multiply(four);

tmp>>=1;

}

sum=sum.subtract(one);

sum=sum.divide(three);

}

System.out.println(sum);

}

}

}

Java利用while求一等比数列_UPC-6760 Problem H  九连环  【重庆OI2018】等比数列求和JAVA高精度...相关推荐

  1. java利用数组求平均值_Java程序使用数组计算平均值

    Java程序使用数组计算平均值 在此程序中,您将学习计算Java中给定数组的平均值. 示例:使用数组计算平均值的程序 public class Average { public static void ...

  2. Java利用while求一等比数列_UPC-6760 Problem H九连环【重庆OI2018】等比数列求和JAVA高精度...

    题目描述 九连环是一种源于中国的传统智力游戏.如图所示,九个圆环套在一把"剑"上,并且互相牵连.游戏的目标是把九个圆环从"剑"上卸下. 圆环的装卸需要遵守两个规 ...

  3. java利用子类求正方形_Java程序设计实验2011

    (2)掌握对象的声明和使用: (3)掌握构造方法的概念和使用: (4)掌握类及成员的访问控制符. 2.实验任务 (1)阅读下面的程序,在main()方法里添加语句完成如下的功能: ①创建一个MyV a ...

  4. java利用栈求复杂表达式_java中的栈Stack的基本使用和应用(二) ——利用栈计算合法的算术表达,中缀表达式转后缀表达式...

    利用栈Stack计算合法的算术表达式 限定的算术表达式求值问题:包含 "+"."-"."*"."/" .正整数和圆括号的 ...

  5. java利用子类求正方形_Java 作业 重写正方形周长方法

    题目 编写一个应用程序,再创建一个矩形类,类中具有长,宽两个成员变量和求周长的方法. 再创建一个矩形类子类, 正方形类,类中定义求面积方法,重写周长方法,在主类中,输入一个正方形的边长,在创建正方形对 ...

  6. JAVA利用数组求两点距离_利用java、js或mysql计算高德地图中两坐标之间的距离

    利用java.js或mysql计算高德地图中两坐标之间的距离 2019-09-19 编程之家收集整理的这篇文章主要介绍了利用java.js或mysql计算高德地图中两坐标之间的距离,编程之家小编觉得挺 ...

  7. java 利用飞信,Java利用飞信API给自己或者好友发信息

    Java利用飞信接口,可以给好友或者自己发送信息. 1.[代码][Java]代码 package com.crawler.core; import java.io.IOException; impor ...

  8. java利用实现大数阶乘(三种方法)

    java利用实现大数阶乘(三种方法) 法一: for循环 import java.math.BigInteger; import java.util.Scanner; public class das ...

  9. java利用poi读取excel_java利用POI读取excel文件的方法

    摘要:利用java读取excel文件,读取文件并获取文件中每一个sheet中的值. 一.需要提前导入的包: import java.io.File; import java.io.FileInputS ...

最新文章

  1. 论坛报名 | AI赋能未来交通
  2. ubuntu装双系统win7和linux,Ubuntu下安装WIn7(双系统)
  3. Modelsim se仿真Xilinx IPcore
  4. mat-form-field must contain a MatFormFieldControl错误的解决方法
  5. java函数只有参数类不一样_java的函数参数传递
  6. mysql特有语法_MySQL 独有SQL语法汇总(一)
  7. Mac上翻译不在 Safari 中网站的方法
  8. noip2011——普及组——瑞士轮
  9. 使用之后,谈谈国产芯片的体验
  10. NPM ----快速删除node_modules
  11. StackPanel
  12. 奥维互动地图恢复旧版及导入谷歌卫星图
  13. 【托业】【新托业TOEIC新题型真题】学习笔记7-题库二-P1~4
  14. Android闹钟制作过程图,小学闹钟手工制作步骤详解(配图)
  15. 家庭组网 光猫+交换机利用VLAN划分实现客厅单线复用(下) 将各房间网口接入家庭局域网
  16. matlab画图双坐标轴和多坐标轴代码
  17. MySql 基本sql语句
  18. 数据推荐 | 人体行为识别数据集
  19. 随笔日记2018 4.10 关于多选框
  20. 指针、野指针、指针常量、常量指针

热门文章

  1. Linux用户和用户组(包含两者之间的关系)
  2. 公司固定资产(车辆)处置的流程以及分录
  3. 有道云笔记新版上线 深化本土应用合作
  4. php获取时间不正确,学习猿地-php获取时间不对的解决办法
  5. 楚纳阻止电动车进电梯,禁止电瓶车上电梯,电梯管控装置
  6. ​​阿里为什么不用 Zookeeper 做服务发现?
  7. 用英语简述计算机的启动过程,计算机的启动过程(详细)
  8. Android 英语单词本英语单词记单词有登陆注册界面Android studio编译
  9. 论文阅读 L2M-GAN:《L2M-GAN: Learning to Manipulate Latent Space Semantics for Facial Attribute Editing》
  10. 灵星之光-1:调制解调、卷积神经网络异曲同工