【高精度】【找规律】Gym – 101243B – Hanoi tower

【高精度】【找规律】Gym – 101243B – Hanoi tower

大家好,又见面了,我是全栈君。

题意:给你一个经典的汉诺塔递归程序,问你最少几步使得三个柱子上的盘子数量相同。(保证最开始盘子数量可以被3整除)

规律:ans(n)=2^(2*n/3-1)+t(n/3)。

t(1)=0.

t(n)=

t(n-1)+1,n为偶数

t(n-1)*4+2,n为奇数。

Java文件读写主要有以下两种方法,第二种,输出格式更随心所欲,更实用:

import java.util.*;
import java.io.*;
import java.math.*;

public class Main{
	public static void main(String[] argc){
		BigInteger[] t=new BigInteger[305];
		BigInteger[] pw=new BigInteger[305];
		t[1]=BigInteger.ZERO;
		for(int i=2;i<=100;++i){
			if(i%2==0){
				t[i]=t[i-1].add(BigInteger.ONE);
			}
			else{
				t[i]=t[i-1].multiply(BigInteger.valueOf(4l)).add(BigInteger.valueOf(2l));
			}
		}
		pw[0]=BigInteger.ONE;
		for(int i=1;i<=300;++i){
			pw[i]=pw[i-1].multiply(BigInteger.valueOf(2l));
		}
		Scanner cin = new Scanner(System.in);
		try{cin=new Scanner(new FileInputStream("input.txt"));}catch(Exception e){}
		int n=cin.nextInt();
		cin.close();
		/*pw[2*n/3-1].add(t[n/3]).toString()*/
		File file=new File("output.txt");
		try{
			BufferedWriter bf=new BufferedWriter(new PrintWriter(file));
			bf.append(pw[2*n/3-1].add(t[n/3]).toString());
			bf.close();
		}
		catch(Exception e){}
    }
}

import java.util.*;
import java.io.*;
import java.math.*;

public class Main{
	public static void main(String[] argc){
		BigInteger[] t=new BigInteger[305];
		BigInteger[] pw=new BigInteger[305];
		t[1]=BigInteger.ZERO;
		for(int i=2;i<=100;++i){
			if(i%2==0){
				t[i]=t[i-1].add(BigInteger.ONE);
			}
			else{
				t[i]=t[i-1].multiply(BigInteger.valueOf(4l)).add(BigInteger.valueOf(2l));
			}
		}
		pw[0]=BigInteger.ONE;
		for(int i=1;i<=300;++i){
			pw[i]=pw[i-1].multiply(BigInteger.valueOf(2l));
		}
		Scanner cin = new Scanner(System.in);
		try{cin=new Scanner(new FileInputStream("input.txt"));}catch(Exception e){}
		int n=cin.nextInt();
		cin.close();
		/*pw[2*n/3-1].add(t[n/3]).toString()*/
		//File file=new File("output.txt");
		try{
			FileWriter fw = new FileWriter("output.txt", true);
			PrintWriter cout = new PrintWriter(fw);
			cout.println(pw[2*n/3-1].add(t[n/3]));
			cout.flush();
			//BufferedWriter bf=new BufferedWriter(new PrintWriter(file));
			//bf.append(pw[2*n/3-1].add(t[n/3]).toString());
			//bf.close();
		}
		catch(Exception e){}
    }
}

转载于:https://www.cnblogs.com/autsky-jadek/p/7625774.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108122.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Win10 IIS Web服务器安装与配置

    Win10 IIS Web服务器安装与配置这几天课程实训,使用IIS配置服务器,课本上内容太久,老师也没有讲过,自己摸索了一下,所以记录一下安装IIS打开程序和功能,选择左边启用或关闭Windows功能,建议根据下图勾选,确定后等待安装完成打开IIS直接使用Cortana搜索管理工具,打开选择InternetinformationServices(IIS)管理器点击左边栏,在计算机名下,网站文件夹下已经默认存

    2022年5月30日
    41
  • 清除SVN未版控文件

    清除SVN未版控文件

    2021年10月20日
    43
  • 美丽的表格样式(使用CSS样式表控制表格样式)

    美丽的表格样式(使用CSS样式表控制表格样式)

    2021年12月1日
    99
  • Word公式自动编号

    Word公式自动编号背景用 Word 写毕业论文 要插入公式 添加公式引用 如果手动操作 维护起来非常难受 本经验详细介绍如果自动维护更新这些公式编号 步骤首先 看一下效果图新建一个 1 3 的表格设置表格属性 比较简单 合在一起写 有多张截图 1 设置单元格边距为 0 2 所有单元格垂直居中 3 左右单元格 设置宽度为 1 厘米 4 中间单元格水平居中对齐 右边单元格水平右对齐

    2025年7月9日
    2
  • idea2021.7.21激活码[免费获取]「建议收藏」

    (idea2021.7.21激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~MLZPB5EL5Q-eyJsaWNlb…

    2022年3月21日
    54
  • Eclipse导入Github上的Robotium源码进行代码分析的步骤

    Eclipse导入Github上的Robotium源码进行代码分析的步骤这篇文章应该只是针对像我这样的初级Maven用户的,因为自己花了不少时间来解决这个问题,而网上很多文章描述的也是语焉不详,所以记录下来以便后来如我者可以借鉴一二。文中有几点细节我觉得需要注意的我会高亮出来。1.问题描述今天打算查看一下Robotum(其项目本身基于maven,因为我发现项目中有pom.xml文件)框架的源代码去了解其具体实现以加深理解,但下载后按照认知的方法去Import

    2022年7月25日
    11

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号