我的家庭作业还有另一个问题。这次我知道我一般在哪里,但我可以看到我对代码有一些明显的问题。最近我丢失了钥匙,就像那样。我不确切知道我的代码出错了,但我有个好主意,我希望你帮我找到它。
问题是使用泰勒系列近似pi。 现在,我的问题并不完全是为了让它接近,所以它等于pi。而是使用用户输入的前N个术语 来近似pi 。所以例如,如果我输入2,那么我应该通过前2,因为N = 2。我的问题是printF代表它的方式(并且变量似乎未初始化)。这是我的代码:
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
//program to calculate series of numbers equal to pi/4
//declare variables
int num_Terms;
int sign= 1;
int n;
float sum= 0.0;
float next_Term;
float final_sum;
//prompt user for input
printf("Enter a value for integer n: ");
scanf("%i",&n);
//perform calculations
for(n = 1; n<= num_Terms; n=n+1) {
sum= sum+next_Term;
next_Term = sign*(1.0/(2*n-1));
sign = sign*-1;
}
final_sum = sum*4;
//display result
printf("\n 4 * %f = %f\n",sum, final_sum);
return 0;
}
答案 0 :(得分:1)
我不知道我的代码出错的地方
首先,您将值扫描到变量 n 中,然后将其用作迭代器变量。将其更改为 num_Terms 。这应该可以解决您不考虑术语数量的主要问题。
然后,最好在使用它之前初始化变量,这样就可以消除你得到的警告。
int main(void)
{
//program to calculate series of numbers equal to pi/4
//declare variables
int num_Terms = 0;
int sign = 1;
int n = 0;
float sum = 0;
float next_Term = 0;
float final_sum = 0;
//prompt user for input
printf("Enter a value for integer n: ");
scanf("%i",&num_Terms);
//perform calculations
for(n = 1; n<= num_Terms; n=n+1) {
//not too sure if you need to reverse this order of calculation of sum
sum = sum + next_Term;
next_Term = sign * (1.0/(2*n-1));
sign = sign * -1;
}
final_sum = sum * 4;
//display result
printf("\n 4 * %f = %f\n",sum, final_sum);
return 0;
}