例4-1使用格雷戈里公式求π的近似值,要求精确到最后一项的绝对值小于10的-4次方。
π/4=1-1/3+1/5-1/7+……
#include <stdio.h>
#include <math.h>
int main()
{
int denominator, flag;
double item, pi; //pi用于存放累加和
/*循环初始化*/
flag = 1;
denominator = 1;
item = 1.0;
pi = 0;
while (fabs(item) >= 0.0001) //当|item|>=0.0001时,执行循环
{
item = flag * 1.0 / denominator; //计算第i项的值
pi = pi + item; //累加第i项的值
flag = -flag; //改变符号
denominator += 2; //分母每次加2
}
pi = pi * 4; //循环结结果是pi/4
printf("pi=%.4f\n", pi);
return 0;
}
例4-2 更改例3-3,从键盘输入一批学生的成绩,计算平均成绩,并统计不及格学生的人数。
#include <stdio.h>
int main()
{
int count, num;
double grade, total;
/*循环初始化*/
num = 0;
total = 0;
count = 0;
printf("Enter grade:");
scanf("%lf", &grade);
while (grade >= 0)//判断输入是否大于0
{
total = total + grade;//累加输入的成绩
num++;//每输入一个成绩,计数
if (grade < 60)//判断成绩是否小于60
{
count++;//统计不及格人数
}
scanf("%lf", &grade);//读入一个新数据,为下次循环准备
}
if (num != 0)
{
printf("Grade average is %.2f\n", total / num);
printf("The failures is %d\n", count);
}
else
{
printf("Grade average is 0\n");
}
return 0;
}
练习4-3:序列求和(1-1/4+1/7-1/10+1/13……):输入一个正实数eps,计算序列的值,精确到最后一项的绝对值小于eps(保留6位小数)。试编写相应程序
正实数:大于0。
最后一项的绝对值小于eps
#include <stdio.h>
#include <math.h>
int main()
{
int flag,denominator;
double item,sum,eps;
/*循环初始化*/
flag=1;
denominator=1;
sum=0;
item=1;
printf("Enter eps:");
scanf("%lf",&eps);
if (eps>=1)
{
sum=1;
}
else
{
while (fabs(item)>=eps)
{
item=flag*1.0/denominator;
sum=sum+item;
flag=-flag;
denominator=denominator+3;
}
}
printf("%.6f\n",sum);
return 0;
}