java中四种阶乘的计算
package com.zf.s2; //创建一个包 import java.math.BigInteger; //导入类 import java.util.ArrayList; import java.util.List; public class TextFactorial { //操作计算阶乘的类 public static int simpleCircle( int num){ //简单的循环计算的阶乘 int sum= 1 ; if (num< 0 ){ //判断传入数是否为负数 throw new IllegalArgumentException( "必须为正整数!" ); //抛出不合理参数异常 } for ( int i= 1 ;i<=num;i++){ //循环num sum *= i; //每循环一次进行乘法运算 } return sum; //返回阶乘的值 } public static int recursion( int num){ //利用递归计算阶乘 int sum= 1 ; if (num < 0 ) throw new IllegalArgumentException( "必须为正整数!" ); //抛出不合理参数异常 if (num== 1 ){ return 1 ; //根据条件,跳出循环 } else { sum=num * recursion(num- 1 ); //运用递归计算 return sum; } } public static long addArray( int num){ //数组添加计算阶乘 long []arr= new long [ 21 ]; //创建数组 arr[ 0 ]= 1 ; int last= 0 ; if (num>=arr.length){ throw new IllegalArgumentException( "传入的值太大" ); //抛出传入的数太大异常 } if (num < 0 ) throw new IllegalArgumentException( "必须为正整数!" ); //抛出不合理参数异常 while (last<num){ //建立满足小于传入数的while循环 arr[last+ 1 ]=arr[last]*(last+ 1 ); //进行运算 last++; //last先进行运算,再将last的值加1 } return arr[num]; } public static synchronized BigInteger bigNumber( int num){ //利用BigInteger类计算阶乘 ArrayList list = new ArrayList(); //创建集合数组 list.add(BigInteger.valueOf( 1 )); //往数组里添加一个数值 for ( int i = list.size(); i <= num; i++) { BigInteger lastfact = (BigInteger) list.get(i - 1 ); //获得第一个元素 BigInteger nextfact = lastfact.multiply(BigInteger.valueOf(i)); //获得下一个数组 list.add(nextfact); } return (BigInteger) list.get(num); //返回数组中的下标为num的值 } public static void main(String []args){ //java程序的主入口处 int num= 5 ; int num1= 23 ; System.out.println( "简单的循环计算" +num+ "的阶乘为" //调用simpleCircle +simpleCircle(num)); System.out.println( "利用递归计算" +num+ "的阶乘为" //调用recursion +recursion(num)); System.out.println( "数组添加计算" +num+ "的阶乘为" //调用addArray +addArray(num)); System.out.println( "利用BigInteger类计算" +num1+ "的阶乘为" //调用bigNumber +bigNumber(num1)); } }
|
java中四种阶乘的计算的更多相关文章
- Java中四种引用:强、软、弱、虚引用
这篇文章非常棒:http://alinazh.blog.51cto.com/5459270/1276173 Java中四种引用:强.软.弱.虚引用 1.1.强引用当我们使用new 这个关键字创建对象时 ...
- java中四种引用类型
java中四种引用类型 今天看代码,里面有一个类java.lang.ref.SoftReference把小弟弄神了,试想一下,接触java已经有3年了哇,连lang包下面的类都不了解,怎么混.后来在 ...
- java中四种引用类型(对象的强、软、弱和虚引用)
对象的强.软.弱和虚引用在JDK 1.2以前的版本中,若一个对象不被任何变量引用,那么程序就无法再使用这个对象.也就是说,只有对象处于可触及(reachable)状态,程序才能使用它.从JDK 1.2 ...
- Java中四种访问权限总结
一.Java中有四种访问权限, 其中三种有访问权限修饰符,分别为private.public.protected,还有一种不带任何修饰符(default). 1. private: Java语言中对访 ...
- Java中四种遍历Map对象的方法
方法一:在for-each循环中使用entry来遍历,通过Map.entrySet遍历key和value,这是最常见的并且在大多数情况下也是最可取的遍历方式.在键值都需要时使用. Map<Int ...
- java中四种操作(dom、sax、jdom、dom4j)xml方式详解与比较
1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特 ...
- java中四种操作xml方式的比较
1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息. ...
- java中四种访问修饰符
Java中的四种访问修饰符:public.protected.default(无修饰符,默认).private. 四种修饰符可修饰的成分(类.方法.成员变量) public protected d ...
- Java中四种引用的区分
强引用(StrongReference) 强引用就是指在程序代码之中普遍存在的,比如下面这段代码中的object和str都是强引用: 1 2 Object object = new Object(); ...
随机推荐
- Git学习笔记——一个NB的分布式版本控制系统
1. 命令: git init 创建新仓库 (在一个空文件下然后执行命令) git clone + 路径 检出仓库,从本地或从服务器上 git status 查 ...
- 转-JS之Window对象
一.说明:他是JS中最大的对象,它描述的是一个浏览器窗口,一般要引用他的属性和方法时,不需要用“Window.XXX”这种形式,而是直接使用“XXX”.一个框架页面也是一个窗口. 二.Window窗口 ...
- 看css发现一个pointer-events:none;的东西
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- window.parent ,window.top,window.self 详解
在应用有frameset或者iframe的页面时,parent是父窗口,top是最顶级父窗口(有的窗口中套了好几层frameset或者iframe),self是当前窗口, opener是用open方法 ...
- 【HDU 5105】Math Problem
题意 f(x)=|ax3+bx2+cx+d| 求f(x)在L≤x≤R的最大值. 分析 参数有可能是0,注意分类讨论 1.当a=0时 b=0,f为一次函数(c≠0)或者常数函数(c=0),最大值点在区间 ...
- 从TP、FP、TN、FN到ROC曲线、miss rate、行人检测评估
从TP.FP.TN.FN到ROC曲线.miss rate.行人检测评估 想要在行人检测的evaluation阶段要计算miss rate,就要从True Positive Rate讲起:miss ra ...
- HOPE——懦怯囚禁人的灵魂,希望可以感受自由。强者自救,圣者渡人。
人世间最美好的,就是希望 人世间最美好的,就是友谊 祝福所有相信希望的人,因为每个充满希望的人,都如此美丽. <肖申克的救赎>中的经典台词 1.Hope is a good thing, ...
- POJ2411 Mondriaan's Dream
Description Squares and rectangles fascinated the famous Dutch painter Piet Mondriaan. One night, af ...
- MySQL各版本的区别(转)
MySQL 的官网下载地址:http://www.mysql.com/downloads/ 在这个下载界面会有几个版本的选择. 1. MySQL Community Server 社区版本,开源免费, ...
- .NET设计模式(2):单件模式(Singleton Pattern)(转载)
概述 Singleton模 式要求一个类有且仅有一个实例,并且提供了一个全局的访问点.这就提出了一个问题:如何绕过常规的构造器,提供一种机制来保证一个类只有一个实例?客户程 序在调用某一个类时,它是不 ...