近似Pi / Taylor系列;提示用户输入

时间:2015-10-02 03:44:21

标签: c user-input pi taylor-series

我的家庭作业还有另一个问题。这次我知道我一般在哪里,但我可以看到我对代码有一些明显的问题。最近我丢失了钥匙,就像那样。我不确切知道我的代码出错了,但我有个好主意,我希望你帮我找到它。

问题是使用泰勒系列近似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;
}

1 个答案:

答案 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;
}