文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

c语言之如何求e的近似值

2022-12-08 20:54

关注

如何求e的近似值

自然常数 e 可以用级数 1+1/1!+1/2!+⋯+1/n!+⋯ 来近似计算。本题要求对给定的非负整数 n,求该级数的前 n+1 项和。

输入格式:

输入第一行中给出非负整数 n(≤1000)。

输出格式:

在一行中输出部分和的值,保留小数点后八位。

输入样例:
10

      
    
输出样例:
2.71828180

我的答案

#include <stdio.h>
int main()
{
    int n;
    double sum = 1, temp = 1;//注意是n+1项,所以先令sum=1
    scanf("%d", &n);
    for (int i = 1; i <= n; i++)
    {
        temp *= i;
        sum += 1.0 / temp;
    }
    printf("%.8lf",sum);
    return 0;
}

求e的近似值(巧用保留位数,拒绝最大值溢出)

题目:

自然常数 e 可以用级数 1+1/1!+1/2!+⋯+1/n!+⋯ 来近似计算。本题要求对给定的非负整数 n,求出该级数的前 n+1 项和。

输入格式:

输入第一行中给出非负整数 n(≤1000)

输出格式:

在一行中输出部分和的值,保留小数点后八位

注意:

一开始,n按照输入格式中给定的条件设置为≤1000,,,果然数据溢出了,用long long int也拯救不了的那种,结果如下:

然后想到用数组存下来,,更难了好吗o(╥﹏╥)o!!!

突然,输出格式中保留小数点后八位,一下子亮了,简直是高光啊!以这个为参照,截取不就好了,具体见代码部分。

事实上,当m<=0.00000001时,满足条件的第一个m=0.0000000021,后面项的值更小,所以在此处截取对保留8位数的结果不会进行损耗。

代码:

#include<stdio.h>
int main(){
    int num;
    long long int n=1;
    double m,sum=1;
    scanf("%d",&num);
    if(num>=0&&num<=1000){
        for(int i=1;i<=num;i++){
            n*=i;    //n表示n!
            m=1.0/n; 
            sum+=m;
            if(m<=0.00000001){ //当某一项的值小于八位小数时,跳出循环
                break;
            }
            
        }
         
         printf("%.08lf",sum);
    }
    return 0;
}

结果:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯