ferocitas 2021-07-24 12:05 采纳率: 100%
浏览 167
已结题

累加求和直到最后一项的值小于1e-6应该怎么写?

是这个样子?

int s;
float n,term;
double sum;
term=1,s=1,n=1,sum=1;
while(fabs(term)>=1e-6)
{
    s=-s; 
    n++;
    term=s/n;
    sum=sum+term;
}

还是这个样子呢

 int s;
 float n,term;
 double sum;
  term=1,s=1,n=1,sum=0;
  while(fabs(term)>=1e-6)
    {
        sum=sum+term;
        s=-s; 
        n++;
        term=s/n;
        }


如果是第二种的话最后一项不就不会加在总数里吗?
以及为什么定义的时候要将n定义为浮点数?为什么定义为整数代码会出错?

  • 写回答

1条回答 默认 最新

  • 关注

    用第一段代码,n如果是整形,term=s/n;只能返回整形,如果小于1返回结果是0,整形相除只能返回整形。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月2日
  • 已采纳回答 7月25日
  • 创建了问题 7月24日

悬赏问题

  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效
  • ¥15 高德地图点聚合中Marker的位置无法实时更新
  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错