- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第一次上机作业
侯创 142136
//student number is 142136
//code begain
#include iostream
using namespace std;
int main()
{
float num[3] = { 100, 10000, 1000000 };
float result1[3] = { 0, 0, 0 };
float result2[3] = { 0, 0, 0 };
for (int i = 0; i 3; i++)
{
for (float j = 2; j = num[i]; j++)
{
result1[i] += 1 / (j*j - 1);
}
for (float k = num[i]; k = 2; k--)
{
result2[i] += 1 / (k*k - 1);
}
}
for (int i = 0; i 3; i++)
{
cout The number that was plushed : num[i]endl;
cout The Precise Number is : 1.0/2.0 * (1.5 - 1.0 / num[i] - 1.0/ (num[i] + 1.0))endl;
cout The expression(1)s result is : result1[i]endl;
cout The expression(1)s result is : result2[i]endlendl;
}
cin result1[1];
return 0;
}
//code ends
运行截图
数列项数为100时,公式(1)有5位有效位,公式(2)全是有效位
数列项数为10000时,公式(1)有4位有效位,公式(2)全是有效位
数列项数为1000000时,公式(1)有4位有效位,公式(2)全是有效位
作业体会
通过这次上机作业,主要程序结果有两个,第一是采用从小数往大数累加精确度比从大数往小数累加精确度高。对于本次作业,公式(2)的加数不断增大,被加数也不断增大,保证了两个相加的数,大小相对接近。减少误差。对于第一个公式,整个数列逐渐缩小,那么加和的过程是加数逐渐变大,但是被加数逐渐缩小,即大数加小数,所以会有小数背吃掉,导致结果出现偏差,但是因为计算机本身字长较长,所以误差比较小。
原创力文档


文档评论(0)