HDU--2011
1260 ワード
多項式の和
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 51327 Accepted Submission(s): 29881
Problem Description
多項式の説明は次のとおりです.
1 - 1/2 + 1/3 - 1/4 + 1/5 - 1/6 + ...
今、この多項式の前のn項の和を求めてください.
Input
入力データは2行からなり、まず正の整数m(m<100)であり、試験例の個数を表し、2行目はm個の正の整数を含み、各整数(n,n<1000としてもよい)について、この多項式の前のn項の和を求める.
Output
各テストインスタンスnについては、多項式の前のn項の和を出力する必要があります.各テストインスタンスの出力は1行を占め、結果は2桁の小数を保持します.
Sample Input
Sample Output
Author
lcy
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 51327 Accepted Submission(s): 29881
Problem Description
多項式の説明は次のとおりです.
1 - 1/2 + 1/3 - 1/4 + 1/5 - 1/6 + ...
今、この多項式の前のn項の和を求めてください.
Input
入力データは2行からなり、まず正の整数m(m<100)であり、試験例の個数を表し、2行目はm個の正の整数を含み、各整数(n,n<1000としてもよい)について、この多項式の前のn項の和を求める.
Output
各テストインスタンスnについては、多項式の前のn項の和を出力する必要があります.各テストインスタンスの出力は1行を占め、結果は2桁の小数を保持します.
Sample Input
2
1 2
Sample Output
1.00
0.50
Author
lcy
#include <iostream>
#include <cmath>
#include <stdio.h>
using namespace std;
int main()
{
int n;
cin >> n;
while (n--)
{
int m;
double sum = 0;
cin >> m;
for (int i=1; i<=m; i++)
{
double num;
num = (double)1/i;
sum = sum + pow(-1,i+1) * num;
}
printf("%.2lf
",sum);
}
return 0;
}