*已知如下公式: 下面程序的功能使根据上述公式输出满足精度要求的eps的 值,请填空使程序完整。*/ #include<stdio.h> #include<math.h> int main ( ) { double s=0.0,eps,t=1.0; int n ; scanf ("%lf",&eps); for (n=1 ; t>=fabs(eps); n++) { s+=t ; /**********FILL**********/ t= [1] ; } /**********FILL**********/ [2] ; return 0; }
时间: 2023-07-18 11:46:18 浏览: 357
以下是填空后的程序:
```c
#include <stdio.h>
#include <math.h>
int main() {
double s = 0.0, eps, t = 1.0;
int n;
scanf("%lf", &eps);
for (n = 1; t >= fabs(eps); n++) {
s += t;
t = pow(0.5, n) / n; // 填空1
}
printf("ln2 = %lf\n", s); // 填空2
return 0;
}
```
其中,第一个空应填 `pow(0.5, n) / n`,表示计算公式中的第二项;第二个空应填 `printf("ln2 = %lf\n", s);`,表示输出计算结果。
程序的主要思路是按照公式进行求和,直到满足精度要求为止。其中,`t` 表示当前要加入求和中的项,`n` 表示当前是第几项,`s` 表示当前的求和结果。
阅读全文