Java利用while求一等比数列_UPC-6760 Problem H 九连环 【重庆OI2018】等比数列求和JAVA高精度...
题目描述
九连环是一种源于中国的传统智力游戏。如图所示,九个圆环套在一把“剑”上,并且互相牵连。游戏的目标是把九个圆环从“剑”上卸下。
圆环的装卸需要遵守两个规则。
第一个(最右边)环任何时候都可以装上或卸下。
如果第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高精度...相关推荐
- java利用数组求平均值_Java程序使用数组计算平均值
Java程序使用数组计算平均值 在此程序中,您将学习计算Java中给定数组的平均值. 示例:使用数组计算平均值的程序 public class Average { public static void ...
- Java利用while求一等比数列_UPC-6760 Problem H九连环【重庆OI2018】等比数列求和JAVA高精度...
题目描述 九连环是一种源于中国的传统智力游戏.如图所示,九个圆环套在一把"剑"上,并且互相牵连.游戏的目标是把九个圆环从"剑"上卸下. 圆环的装卸需要遵守两个规 ...
- java利用子类求正方形_Java程序设计实验2011
(2)掌握对象的声明和使用: (3)掌握构造方法的概念和使用: (4)掌握类及成员的访问控制符. 2.实验任务 (1)阅读下面的程序,在main()方法里添加语句完成如下的功能: ①创建一个MyV a ...
- java利用栈求复杂表达式_java中的栈Stack的基本使用和应用(二) ——利用栈计算合法的算术表达,中缀表达式转后缀表达式...
利用栈Stack计算合法的算术表达式 限定的算术表达式求值问题:包含 "+"."-"."*"."/" .正整数和圆括号的 ...
- java利用子类求正方形_Java 作业 重写正方形周长方法
题目 编写一个应用程序,再创建一个矩形类,类中具有长,宽两个成员变量和求周长的方法. 再创建一个矩形类子类, 正方形类,类中定义求面积方法,重写周长方法,在主类中,输入一个正方形的边长,在创建正方形对 ...
- JAVA利用数组求两点距离_利用java、js或mysql计算高德地图中两坐标之间的距离
利用java.js或mysql计算高德地图中两坐标之间的距离 2019-09-19 编程之家收集整理的这篇文章主要介绍了利用java.js或mysql计算高德地图中两坐标之间的距离,编程之家小编觉得挺 ...
- java 利用飞信,Java利用飞信API给自己或者好友发信息
Java利用飞信接口,可以给好友或者自己发送信息. 1.[代码][Java]代码 package com.crawler.core; import java.io.IOException; impor ...
- java利用实现大数阶乘(三种方法)
java利用实现大数阶乘(三种方法) 法一: for循环 import java.math.BigInteger; import java.util.Scanner; public class das ...
- java利用poi读取excel_java利用POI读取excel文件的方法
摘要:利用java读取excel文件,读取文件并获取文件中每一个sheet中的值. 一.需要提前导入的包: import java.io.File; import java.io.FileInputS ...
最新文章
- 论坛报名 | AI赋能未来交通
- ubuntu装双系统win7和linux,Ubuntu下安装WIn7(双系统)
- Modelsim se仿真Xilinx IPcore
- mat-form-field must contain a MatFormFieldControl错误的解决方法
- java函数只有参数类不一样_java的函数参数传递
- mysql特有语法_MySQL 独有SQL语法汇总(一)
- Mac上翻译不在 Safari 中网站的方法
- noip2011——普及组——瑞士轮
- 使用之后,谈谈国产芯片的体验
- NPM ----快速删除node_modules
- StackPanel
- 奥维互动地图恢复旧版及导入谷歌卫星图
- 【托业】【新托业TOEIC新题型真题】学习笔记7-题库二-P1~4
- Android闹钟制作过程图,小学闹钟手工制作步骤详解(配图)
- 家庭组网 光猫+交换机利用VLAN划分实现客厅单线复用(下) 将各房间网口接入家庭局域网
- matlab画图双坐标轴和多坐标轴代码
- MySql 基本sql语句
- 数据推荐 | 人体行为识别数据集
- 随笔日记2018 4.10 关于多选框
- 指针、野指针、指针常量、常量指针
热门文章
- Linux用户和用户组(包含两者之间的关系)
- 公司固定资产(车辆)处置的流程以及分录
- 有道云笔记新版上线 深化本土应用合作
- php获取时间不正确,学习猿地-php获取时间不对的解决办法
- 楚纳阻止电动车进电梯,禁止电瓶车上电梯,电梯管控装置
- ​​阿里为什么不用 Zookeeper 做服务发现?
- 用英语简述计算机的启动过程,计算机的启动过程(详细)
- Android 英语单词本英语单词记单词有登陆注册界面Android studio编译
- 论文阅读 L2M-GAN:《L2M-GAN: Learning to Manipulate Latent Space Semantics for Facial Attribute Editing》
- 灵星之光-1:调制解调、卷积神经网络异曲同工