大数问题,通常用JAVA
e.g.
HDU1002
简单加法
import java.math.BigInteger;
import java.util.Scanner; public class Main {
public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
int t=cin.nextInt();
cin.nextLine();
int cnt=;
while(t!=)
{
t--;
String s1=cin.next();
String s2=cin.next();
BigInteger a1=new BigInteger(s1);
BigInteger a2=new BigInteger(s2);
System.out.println("Case "+(++cnt)+":");
System.out.print(a1+" + "+a2+" = ");
System.out.println(a1.add(a2));
if(t!=)
System.out.println();
} }
}
HDU1715 大斐波那契数
import java.math.BigInteger;
import java.util.Scanner; public class Main {
private static BigInteger[] fib;
public static void f(){
fib=new BigInteger[1005];
fib[2]=new BigInteger("1");
fib[1]=fib[2];
for(int i=3;i<1005;i++)
{
fib[i]=fib[i-1].add(fib[i-2]);
}
}
public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
int t=cin.nextInt();
cin.nextLine();
int cnt=0;
f();
while(t!=0)
{
t--;
cnt=cin.nextInt();
System.out.println(fib[cnt]);
} }
}
分析(转):
简单递推+大数。
f[n]=f[n-1]+f[n-2]。
why?
由于数字只有'1'和'2'这两种,那么当让第n
位为1的时候,f[n]加上f[n-1];当让最后两位
合并成2的时候,f[n]加上f[n-2](因为要保证
倒数第二位一定是1)。
算出来的f就是一个斐波那契数列。
WOW ,问题转化是极为巧妙的
这种递推关系,说的严重点就是动态规划
import java.math.BigInteger;
import java.util.Scanner; public class Main {
private static BigInteger[] fib;
public static void f(){
fib=new BigInteger[1005];
fib[1]=new BigInteger("1");
fib[0]=fib[1];
for(int i=2;i<1005;i++)
{
fib[i]=fib[i-1].add(fib[i-2]);
}
}
public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
int t=cin.nextInt();
cin.nextLine();
int cnt=0;
f();
while(t!=0)
{
t--;
String s=cin.next();
cnt=s.length();
System.out.println(fib[cnt]);
} }
}
HDU 1753 大明A+B(大小数加法,C模拟,Java BigDecimal)
import java.math.BigDecimal;
import java.util.Scanner; public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
BigDecimal a,b;
while(sc.hasNext()){
a = sc.nextBigDecimal();
b = sc.nextBigDecimal();
System.out.println(a.add(b).stripTrailingZeros().toPlainString());
}
}
}
HDU1316
JAVA水题 暴力 BigInteger 大数
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Scanner; public class Main {
private static BigInteger[] fib;
public static void f(){
fib=new BigInteger[1005];
fib[1]=new BigInteger("1");
fib[0]=fib[1];
for(int i=2;i<1005;i++)
{
fib[i]=fib[i-1].add(fib[i-2]);
}
}
public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
BigInteger a1,a2;
f();
BigInteger dumy=BigInteger.ZERO;
while(cin.hasNextBigInteger())
{
a1=cin.nextBigInteger();
a2=cin.nextBigInteger();
if(a1.compareTo(dumy)==0&&a2.compareTo(dumy)==0){
break;
}
int cnt=0;
for(int i=1;i<1005;i++)
{
if(fib[i].compareTo(a2)>0)break;
if(fib[i].compareTo(a1)>=0&&fib[i].compareTo(a2)<=0){
cnt++;
}
}
System.out.println(cnt);
} } }
HDU1047
Integer Inquiry 大数加法
注意输出格式
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Scanner; public class Main { public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
int n=cin.nextInt();
BigInteger d1,z=BigInteger.ZERO,sum;
while((n--)!=0)
{
sum=z;
while(cin.hasNextBigInteger())
{
d1=cin.nextBigInteger();
if(d1.equals(z)){
break;
}
sum=sum.add(d1);
}
System.out.println(sum);
if(n!=0){
System.out.println();
}
} }
}
HDU1063
大数的幂
.stripTrailingZeros().toPlainString()
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Scanner; public class Main { public static void main(String[] args) {
Scanner cin=new Scanner(System.in);
BigDecimal b1,ans,o=BigDecimal.ONE;
int n;
while(cin.hasNextBigDecimal())
{
b1=cin.nextBigDecimal();
n=cin.nextInt();
ans=o;
for(int i=0;i<n;i++)
{
ans=ans.multiply(b1);
}
if(b1.compareTo(o)<0)
System.out.println(ans.stripTrailingZeros().toPlainString().substring(1));
else
System.out.println(ans.stripTrailingZeros().toPlainString());
}
}
大数问题,通常用JAVA的更多相关文章
- 算法竞赛中的常用JAVA API :大数类(转载)
5.算法竞赛中的常用JAVA API :大数类 摘要 java中的基础数据类型能存储的最大的二进制数是 2 ^ 63 - 1 对应的十进制数是9223372036854775807(long类型的最大 ...
- 8.算法竞赛中的常用JAVA API :Calendar日期类
8.算法竞赛中的常用JAVA API :Calendar日期类 摘要 在蓝桥杯中有关于日期计算的问题,正好java中的Date类和Calendar类提供了对日期处理的一些方法.Date类大部分方法已经 ...
- 常用 Java 静态代码分析工具的分析与比较
常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基 本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBu ...
- 常用Java排序算法
常用Java排序算法 冒泡排序 .选择排序.快速排序 package com.javaee.corejava; public class DataSort { public DataSort() { ...
- 【转载】常用 Java 静态代码分析工具的分析与比较
摘自:http://www.oschina.net/question/129540_23043常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后 ...
- LSM Tree 学习笔记——MemTable通常用 SkipList 来实现
最近发现很多数据库都使用了 LSM Tree 的存储模型,包括 LevelDB,HBase,Google BigTable,Cassandra,InfluxDB 等.之前还没有留意这么设计的原因,最近 ...
- 常用Java API之Ramdom--用代码模拟猜数小游戏
常用Java API之Ramdom Ramdom类用来生成随机数字.使用起来也是三个步骤: 1.导包 import java.util.Random; 2.创建 Random r = new Rand ...
- 常用Java API之Scanner:功能与使用方法
Scanner 常用Java API之Scanner:功能与使用方法 Scanner类的功能:可以实现键盘输入数据到程序当中. 引用类型的一般使用步骤:(Scanner是引用类型的) 1.导包 imp ...
- 6个常用Java 源代码 保护工具(混淆、加密、底层)
6个常用Java 源代码 保护工具(混淆.加密.底层) ProGuard Java源代码保护工具ProGuard的3.6与4.1版 下载地址:http://download.csdn.net/sou ...
随机推荐
- 8.Mongodb备份与恢复
1.备份 语法 mongodump -h dbhost -d dbname -o dbdirectory -h:服务器地址,也可以指定端口号 -d:需要备份的数据库名称 -o:备份的数据存放位置,此目 ...
- 5 多线程 模拟qq聊天
1.多线程思路 使用多线程完成一个全双工的QQ聊天程序 2.版本1:程序小框架 #1.收数据,然后打印 def recvData(): pass #2.检测键盘,发数据 def sendData(): ...
- 对工具的反思 & deadlines与致歉
人和动物最大的区别就是使用工具的水平. 有些人只凭着对工具的熟练掌握便成了牛人. 工具,到底应该以何种态度去看待? 在我小的时候,工具仅仅是指树枝.线.粉笔,可以让自己有更多游戏可玩:上学之后,便又有 ...
- springmvc基础篇—掌握三种控制器
上一篇文章中我们讲过了处理器的映射,接下来我们来一起学习下springmvc的控制器吧. 首先咱们先创建一个咱们用来测试的实体(model)类: package cn.cfs.springmvc.do ...
- Ubuntu 安装Google浏览器
Ubuntu自带的浏览器是火狐浏览器,使用的时候多多少少有些不方便,这里安装Googel浏览器. 下载 可以到 Ubuntu chrome去下载安装包. 安装 首先到下载的根目录 cd ~/Downl ...
- Word2vec之CBOW
一.Word2vec word2vec是Google与2013年开源推出的一个用于获取word vecter的工具包,利用神经网络为单词寻找一个连续向量看空间中的表示.word2vec是将单词转换为向 ...
- Failed loading D:\Program Files\phpStudy20161103\php\php-5.6.27-nts\ext\php_xdebug.dll
我用的是phpstudy 更新完composer php 切换composer的国内源的时候老是报找不到\php_xdebug.dll的错误, 原因是, 在php.ini 里面默写就是在Program ...
- 并查集——poj1308(并查集延伸)
题目链接:Is It A Tree? 题意:给你一系列形如u v的点对(u v代表一条由u指向v的有向边),请问由给你的点构成的图是不是一棵树? 树的特征:①每个节点(除了根结点)只有一个入度:②只有 ...
- [译]10个有关SCP的命令
原文来源: https://www.tecmint.com/scp-commands-examples/ 基本语法 scp source_file_name username@destination_ ...
- js计算当前日期上一个月和下一个月
/** * 获取上一个月 * * @date 格式为yyyy-mm-dd的日期,如:2014-01-25 */ funct ...