HDU1042 - - N!
Problem Description
Given an integer N(0 ≤ N ≤ 10000), your task is to calculate N!
Input
One N in one line, process to the end of file.
Output
For each N, output N! in one line.
Sample Input
1 2 3
Sample Output
1 2 6
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);
//BigInteger n = cin.nextBigInteger();
int n ;
while(cin.hasNext()){
n = cin.nextInt();
int i;
BigInteger sum = new BigInteger("1");
BigInteger num = new BigInteger("1");
BigInteger addit = new BigInteger("1");
for( i = 1; i <= n; i++){
sum = sum.multiply(num);
num = num.add(addit);
}
System.out.println(sum);
}
}
}
HDU1753 - - A+B
Input
本题目包含多组测试数据,请处理到文件结束。
每一组测试数据在一行里面包含两个长度不大于400的正小数A和B。
每一组测试数据在一行里面包含两个长度不大于400的正小数A和B。
Output
请在一行里面输出输出A+B的值,请输出最简形式。详细要求请见Sample Output。
Sample Input
1.1 2.9 1.1111111111 2.3444323343 1 1.1
Sample Output
4 3.4555434454 2.1
分析:1.采用BigDecimal,但是还有一步,就是需去掉末尾多余的0;
2.如果我们希望去除末尾多余的0,那么我们应该这么写:
System.out.println( new BigDecimal("100.000").stripTrailingZeros().toString());
其中,stripTrailingZeros()函数就是用于去除末尾多余的0的,但是此时程序的输出为: 1E+2
是科学计数法,可能并不是我们想要的。
解决的方法很简单,如果想要避免输出科学计数法的字符串,我们要用toPlainString()函数代替toString()。如:
System.out.println( new BigDecimal("100.000").stripTrailingZeros().toPlainString());
此时程序的输出就为 100(第二条分析来自 使用BigDecimal 将科学计数法变成普通的文本格式输出)
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 a;
BigDecimal b;
BigDecimal sum;
while(cin.hasNext()){
a = cin.nextBigDecimal();
b = cin.nextBigDecimal();
sum = a.add(b).stripTrailingZeros();;
System.out.println(sum.toPlainString());
}
}
}