练习4-3 求给定精度的简单交错序列部分和 (15 分)
时间: 2023-04-21 16:04:12 浏览: 146
题目描述:
给定一个精度 eps(<eps<1),以及一个简单交错序列 {a_n},其中 a_n 的绝对值单调递减,且 lim a_n=。求该序列的部分和 S,使得 |S-S*|<eps,其中 S* 为精确值。
输入格式:
输入第一行为一个正整数 N(N<=100),表示序列的长度。第二行包含 N 个实数,表示简单交错序列 {a_n}。
输出格式:
输出一个实数,表示该序列的部分和 S。
输入样例:
5
1. -.5 .3 -.2 .1
输出样例:
.6
解题思路:
本题需要求解的是一个简单交错序列的部分和,使得其与精确值之间的误差小于给定的精度 eps。由于该序列的绝对值单调递减,因此可以采用贪心策略,从大到小依次加入序列中的元素,直到加入一个元素后,其对部分和的贡献小于给定的精度 eps 为止。
具体实现时,可以使用一个变量 sum 记录当前的部分和,以及一个变量 sign 记录当前的符号,初始值为 1。然后从大到小遍历序列中的元素,如果当前元素的绝对值乘以 sign 小于给定的精度 eps,则退出循环,否则将当前元素加入部分和中,并将 sign 取反。最后输出部分和即可。
参考代码:
相关问题
练习4-3 求给定精度的简单交错序列部分和
这道题要求我们计算给定精度下的简单交错序列部分和。
简单交错序列是指序列中相邻两项的符号不同,例如:1,-2,3,-4,5,-6,...
我们需要计算这个序列的部分和,直到达到给定的精度。具体的计算方法是,从第一项开始,每次加上下一项,直到加上的项的绝对值小于给定的精度为止。
例如,如果给定精度为.01,那么我们需要计算出以下部分和:
1 - 2 + 3 - 4 + 5 - 6 + ...
直到加上的项的绝对值小于.01为止。
这个问题可以使用循环来解决。我们可以使用一个变量来记录当前的部分和,然后每次加上下一项,直到加上的项的绝对值小于给定的精度为止。
具体的代码实现可以参考以下示例:
precision = .01 # 给定精度
sum = # 当前部分和
n = 1 # 当前项的值
sign = 1 # 当前项的符号
while abs(n) >= precision:
sum += sign * n
n += 1
sign = -sign
print(sum) # 输出部分和
7-2 求给定精度的简单交错序列部分和 (15 分)
题目描述:
给定一个精度 eps,求简单交错序列的部分和,直到相邻两项之差的绝对值小于 eps 为止。
简单交错序列的定义为:序列的第一项为正数,第二项为负数,第三项为正数,第四项为负数,以此类推。
输入格式:
输入一行两个整数 n 和 eps,其中 n 表示要求的部分和项数,eps 表示要求的精度。
输出格式:
输出一个实数,表示简单交错序列的部分和。
输入样例:
3 .01
输出样例:
1.33
解题思路:
题目要求的是简单交错序列的部分和,直到相邻两项之差的绝对值小于 eps 为止。因此,我们可以先定义一个变量 sum,表示部分和,然后从第一项开始,依次加上第 1 到第 n 项,每次加上一项后,判断相邻两项之差的绝对值是否小于 eps,如果小于 eps,则停止循环,输出当前的部分和。
代码如下:
阅读全文