阶乘比较快速的算法 递归 Java

递归算法,用Java的BigDecimal类



 

 

package com.todo.first;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.Scanner;

/**
 * Created by IntelliJ IDEA.
 * User: Administrator
 * Date: 2010-9-15
 * Time: 15:26:25
 * To change this template use File | Settings | File Templates.
 */
public class mainTest {
    public static void main(String[] args) {
 
        System.out.println("输入要求阶乘数:");
        Scanner scanner = new Scanner(System.in);
        int n = Integer.parseInt(scanner.nextLine());
        BigDecimal bigDecimal = new BigDecimal(0);

 
        bigDecimal=bigDecimal.add(jiecheng(n));
        System.out.println(bigDecimal.toString());
        File file = new File("D://"+n+"!.txt");     //把计算结果保存到D盘文件中

            BufferedWriter os = null;
            try {
                os = new BufferedWriter(new FileWriter(file));
                os.write(file.getName()+"/n"+bigDecimal.toString());
                os.close();
            } catch (IOException e) {
                e.printStackTrace();
            }


    }


//阶乘递归算法
    public static BigDecimal jiecheng(int n) {
        if (n == 1) {
            return new BigDecimal(1);
        }
        return jiecheng(n - 1).multiply(new BigDecimal(n));
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值