java递归比较_阶乘比较快速的算法 递归 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、付费专栏及课程。

余额充值