多项式求和
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
多项式描述如下:
1 - 1/2 + 1/3 - 1/4 + 1/5 - 1/6 ……
先请你求出多项式前n项的和。
Input
第一行输入一个数T代表测试数据个数(T<=1000)。接下来T行每行1个数代表n(0<=n< 2^31)。
Output
对于每个输入样例,输出多项式和的结果(结果精确到小数点后两位)。每行输出一个结果。
Example Input
2 1 2
Example Output
1.00 0.50import java.text.DecimalFormat; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner (System.in); DecimalFormat m = new DecimalFormat( "0.00" ); while( in.hasNext() ){ int t = in.nextInt(); while( t-->0 ){ int n = in.nextInt(); if( n>180 ) n = 180; double sum = 0; F f = new F(); for( int i=1; i<=n; i++ ) sum += f.f(i); System.out.println(m.format(sum)); } } } } class F{ int n; F(){} public F( int n ){ this.n = n; } public double f( int n ){ return Math.pow(-1, n-1)/n; } }