Python123:计算各序列前N项和(C语言)
1、计算序列 1 + 1/3 + 1/5 + … 的前N项之和
题目:本题要求编写程序,计算序列 1 + 1/3 + 1/5 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。
输入样例:
23
输出样例:
sum = 2.549541
代码1:
#include<stdio.h>
int main()
{
int i,n,a,b=1;
double sum=0;
scanf("%d",&n);
for(i=1;i<=n;i++){
a=1;
sum=sum+a*1.0/b;
b=b+2;
}
printf("sum = %.6f",sum);
return 0;
}
代码2:
#include <stdio.h>
int main()
{
int i,n;
double sum=0;
scanf("%d",&n);
for(i=1;i<=n;i++)
sum+=1.0/(2*i-1);
printf("sum = %f\n",sum);
return 0;
}
2、计算平方根序列√1+√2+√3+⋯的前N项之和
题目:本题要求编写程序,计算平方根序列√1+√2+√3+⋯的前N项之和。可包含头文件math.h,并调用sqrt函数求平方根。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后两位。题目保证计算结果不超过双精度范围。
输入样例:
10
输出样例:
sum = 22.47
代码1:
#include<stdio.h>
#include<math.h>
int main()
{
int i,n;
double sum=0;
scanf("%d",&n);
for(i=1;i<=n;i++){
sum+=sqrt(i);
}
printf("sum = %.2f",sum);
return 0;
}
代码2:
#include<stdio.h>
#include <math.h>
int main()
{
int i,n;
double sum=0;
scanf("%d",&n);
for(i=1;i<=n;i++)
sum+=sqrt(i);
printf("sum = %.2f\n",sum);
return 0;
}
3、计算序列部分和 1 - 1/4 + 1/7 - 1/10 + … 直到最后一项的绝对值小于给定精度eps
题目:本题要求编写程序,计算序列部分和 1 - 1/4 + 1/7 - 1/10 + … 直到最后一项的绝对值小于给定精度eps。
输入格式:
输入在一行中给出一个正实数eps。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。
输入样例1:
4E-2
输出样例1:
sum = 0.854457
输入样例2:
0.02
输出样例2:
sum = 0.826310
代码1:
#include<stdio.h>
#include<math.h>
int main()
{
int i=1,flag=1;
double sum=0,eps,a;
scanf("%lf",&eps);
do{
a=flag*1.0/(3*i-2);
i++;
sum=sum+a;
flag=-flag;
}
while(fabs(a)>eps);
if(eps==1){
sum=1-1.0/4;
}
printf("sum = %.6f",sum);
return 0;
}
代码2:
#include <stdio.h>
#include <math.h>
int main()
{
int i=0,flag=1;
double item=1,sum=0,error;
scanf("%lf",&error);
if(error>1)
{
sum=1;
}
else if(error==1)
{
sum=1;
}
else
{
while(fabs(item)>error)
{
item=flag*1.0/(3*i+1);
sum+=item;
flag=-flag;
i++;
}
}
printf("sum = %.6f\n",sum);
return 0;
}