java中不用BigInteger实现超大整数的乘法操作
昨天看到一个题目:计算1234!,不能用BigInteger类
众所周知阶乘的数据会非常大,经常使用的int和long型根本不够用。一般想到的仅仅有BigInteger类,可是题目中明白说了不能用,所以仅仅能想其他办法。
阶乘事实上就是乘法的递归。这道题目能够简化为怎样实现大数据的乘法,int和long型都装不下的数据,仅仅能用String来表示,所以仅仅要实现了两个String表示数字的乘法就可实现题目要求。
想想我们自己手算乘法的步骤。基本都是列一个竖式。分别按位相乘,进位的数相加。
。仅仅要用程序将这个过程模拟出来。就ok了。
列竖式的时候把一个数分成个十百千位。。
事实上就等同于整型数组。。弄清楚了这些。就能够写代码了。
- package cn.baokx;
- public class BigIntMulti{
- public static int [] multi(String str1, String str2) {
- //将接收到的字符串转化成倒序的char数组
- char[] nums1 = new StringBuffer(str1).reverse().toString().toCharArray();
- char[] nums2 = new StringBuffer(str2).reverse().toString().toCharArray();
- //预先声明一个数组,用来存放各个位数相乘的结果(相似于列竖式)
- int len = nums1.length+nums2.length;
- int [] array = new int[len];
- //模拟竖式计算
- for(int i = 0 ; i < nums2.length ; i++){
- for(int j = 0 ; j < nums1.length ; j++){
- array[len-1-(i+j)] += (nums2[i]-48)*(nums1[j]-48);
- }
- }
- return array;
- }
- //对数组进行进位操作。以字符串的形式返回终于结果
- public static String arrayFormat(int [] array){
- for(int i = array.length-1 ; i > 0 ; i--){
- array[i-1] += array[i]/10;
- array[i] = array[i]%10;
- }
- StringBuffer buffer = new StringBuffer();
- if(array[0]!=0){
- buffer.append(array[0]);
- }
- for(int i = 1 ; i < array.length ; i++){
- buffer.append(array[i]);
- }
- return buffer.toString();
- }
- //阶乘
- public static String getFactorial(String num){
- if("1".equals(num)){
- return "1";
- }else{
- return arrayFormat(multi(num,getFactorial((Integer.parseInt(num)-1)+"")));
- }
- }
- public static void main(String[] args) {
- System.out.println(getFactorial("1234"));
- System.out.println(arrayFormat(multi("10","10")));
- System.out.println(arrayFormat(multi("99","99")));
- }
- }
java中不用BigInteger实现超大整数的乘法操作的更多相关文章
- Java中的BigInteger在ACM中的应用
Java中的BigInteger在ACM中的应用 在ACM中的做题时,常常会遇见一些大数的问题.这是当我们用C或是C++时就会认为比較麻烦.就想有没有现有的现有的能够直接调用的BigInter,那样就 ...
- 利用java中的BigInteger实现进制转换
[原创] java中的进制BigInteger十分的强大,而且好用,他可以表示任意大的整数,同时还可以进行进制转换,十分的方便, 代码示例: package com.jiajia.demo_1; im ...
- java中利用RandomAccessFile读取超大文件
超大文件我们使用普通的文件读取方式都很慢很卡,在java中为我提供了RandomAccessFile函数,可以快速的读取超大文件并且不会感觉到卡哦,下面看我的一个演示实例. 服务器的日志文件往往达到4 ...
- java中的BigInteger
头文件 import java.io.*; import java.math.*; 读入 Scanner cin = Scann(System.in); while(cin.hasNext()) &l ...
- Java中利用BigInteger类进行大数开方
在Java中有时会用到大数据,基本数据类型的存储范围已经不能满足要求了,如要对10的1000次方的这样一个数据规模的数进行开方运算,很明显不能直接用Math.sqrt()来进行计算,因为已经溢出了. ...
- Java中分别取数的整数及小数部分
import java.math.BigDecimal; import java.util.Scanner; /** * Created by Administrator on 2016/9/20. ...
- JAVA中定义不同进制整数
1.八进制整数以0开头 int b = 033;//表示十进制数27,3 × 81 + 3 × 80 = 3 × 8 + 3 × 1 = 24 + 3 = 27 2.十六进制整数以0x或者0X开头 i ...
- java中,小数为0,保留整数,不为0,保留小数
- Java 中如何将字符串转换为整数?
String s="123"; int i; 第一种方法:i=Integer.parseInt(s); 第二种方法:i=Integer.valueOf(s).intValue();
随机推荐
- TP 查询语句中如何使用 FIND_IN_SET 这样的查询方法
TP 查询语句中如何使用 FIND_IN_SET 这样的查询方法 $condition['_string'] = 'FIND_IN_SET('.$citys.',city)';
- 基于swiper的移动端H5页面,丰富的动画效果
概述 通过运用swiper插件,制作移动端上下整屏滑动的H5页面,用来宣传或者简单注册等,可以嵌套H5音乐或者视频. 详细 代码下载:http://www.demodashi.com/demo/119 ...
- 微信公共服务平台开发(.Net 的实现)3-------发送文本消息
首先建立一个微信消息类. class wxmessage { public string FromUserName { get; set; } public string ToUserName { g ...
- android Handler的使用(一)
Handler的使用(一) Handler基本概念: Handler主要用于异步消息的处理:当发出一个消息之后,首先进入一个消息队列,发送消息的函数即刻返回,而另外一个部分逐个的在消息队列中将消息取出 ...
- C# Directory类的操作
Directory类位于System.IO 命名空间.Directory类提供了在目录和子目录中进行创建移动和列举操作的静态方法.此外,你还可以访问和操作各种各样的目录属性,例如创建或最后一次修改时间 ...
- 温故而知新 通过chrome tool 查看是否产生闭包
function foo() { var a = 20 var b = 30 function bar() { debugger; return a + b } return bar; } var b ...
- Sublime Text 使用指南 - 前端开发神器
Sublime Text 前端开发的神器 Sublime Text是一个前端开发者必备的编辑器,大量的插件,完善的功能,优越的性能,有非常多的特色,给前端开发提供了一个完善的开发条件. 本文主要介绍的 ...
- Redis 实现接口访问频率限制
为什么限制访问频率 做服务接口时通常需要用到请求频率限制 Rate limiting,例如限制一个用户1分钟内最多可以范围100次 主要用来保证服务性能和保护数据安全 因为如果不进行限制,服务调用者可 ...
- sass 的使用
普通变量 ? 1 $fontSize:12px; 默认变量 ? 1 $fontSize:12px; !default; 变量覆盖:只需要在默认变量之前重新声明下变量即可 ? 1 2 $fontSize ...
- dubbo相关
1 面试题:Dubbo中zookeeper做注册中心,如果注册中心集群都挂掉,发布者和订阅者之间还能通信么? 可以的,启动dubbo时,消费者会从zk拉取注册的生产者的地址接口等数据,缓存在本地.每次 ...