2-14 求奇数分之一序列前N项和
题目要求:
本题要求编写程序,计算序列 1 + 1/3 + 1/5 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。
输入样例:
23
输出样例:
sum = 2.549541
代码实现:
#include <stdio.h>
double ComputeOddSum(int N)
{
int i = 1;
double s = 0;
int count = 1;
for (i = 1; count <= N; i+=2)
{
s = s + 1.0 * 1 / i;
count++;
}
return s;
}
int main()
{
int N = 0;
scanf("%d", &N);
double s = ComputeOddSum(N);
printf("sum = %.6lf\n", s);
return 0;
}
2-15 求简单交错序列前N项和
题目要求:
本题要求编写程序,计算序列 1 - 1/4 + 1/7 - 1/10 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后三位。题目保证计算结果不超过双精度范围。
输入样例:
10
输出样例:
sum = 0.819
代码实现:
#include <stdio.h>
double ComputeSum(int N)
{
int i = 1;
double s = 0;
int count = 1;
int flag = 1;
for (i = 1; count <= N; i+=3)
{
s = s + flag * 1.0 * 1 / i;
flag = -flag;
count++;
}
return s;
}
int main()
{
int N = 0;
double S = 0;
scanf("%d", &N);
S = ComputeSum(N);
printf("sum = %.3lf\n", S);
return 0;
}
2-17 生成3的乘方表
题目要求:
输入一个非负整数n,生成一张3的乘方表,输出30到3n的值。可调用幂函数计算3的乘方。
输入格式:
输入在一行中给出一个非负整数n。
输出格式:
按照幂的递增顺序输出n+1行,每行格式为“pow(3,i) = 3的i次幂的值”。题目保证输出数据不超过长整型整数的范围
输入样例:
3
输出样例:
pow(3,0) = 1
pow(3,1) = 3
pow(3,2) = 9
pow(3,3) = 27
代码实现:
#include <stdio.h>
#include <math.h>
int main()
{
int n = 0;
int i = 0;
long s = 0;
scanf("%d", &n);
for (i = 0; i <= n; i++)
{
s = pow(3, i);
printf("pow(%d,%d) = %ld\n", 3, i, s);
}
return 0;
}