C语言实验——余弦
Time Limit: 1000 ms
Memory Limit: 65536 KiB
Problem Description
输入n的值,计算cos(x)。
Input
输入数据有多行,每行两个数,包括x和n。第一数据为x,第二个数据为n。
Output
输出cos(x)的值,保留4位小数。
Sample Input
0.0 100
Sample Output
1.0000
//原本用的分母用的阶乘的形式,分子用 的乘机却显示NaN,新宇告诉我说,not a number. 想来应该是200的阶乘超出了long的范围。其实,每一项比前一项多了x*x/(2*i-1)/(2*i);这样就不会出现阶乘超出范围的问题了
//总之,一个小题感觉又学会了很多东西。
import java.util.Scanner;
import java.text.DecimalFormat;
public class Main {
public static void main(String args[]) {
Scanner cin = new Scanner(System.in);
DecimalFormat f = new DecimalFormat("0.0000");
while(cin.hasNext()) {
int i;
double x = cin.nextDouble();
int n = cin.nextInt();
double sum = 1;
double h1 = 1;
for(i = 1;i<=n;i++) {
h1 = h1*x*x/(2*i)/(2*i-1);
if(i%2==0) {
sum = sum + h1;
}
else
sum = sum - h1;
}
System.out.println(f.format(sum));
}
cin.close();
}
}