U2yyy 2022-04-19 12:17 采纳率: 71.4%
浏览 454
已结题

求分数序列前N项和的问题

本题要求编写程序,计算序列 2/1+3/2+5/3+8/5+... 的前N项之和。注意该序列从第2项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。

#include<stdio.h>
double slv(int n);
int main(){

int n;

scanf("%d",&n);

printf("%.2f",slv(n));

return 0;

}
double slv(int n){
double sum=0;
int i;
int son=2;
int mother=1;
int mid;
for(i=0;i<n;i++){
sum+=(double)(son)/mother;
mid=son;
son=son+mother;
mother=mid;
}
return sum;
}

整体问题不大,但是pat上显示较大n会出错,不知道什么原因?

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2022-04-19 14:29
    关注

    项数 n 过大,double slv(int n) 函数里 son mother mid 变量的值会超 int 型的范围,修改如下,供参考:

    #include<stdio.h>
    double slv(int n);
    int main() {
        int n;
        scanf("%d", &n);
        printf("%.2f", slv(n));
        return 0;
    }
    double slv(int n) {
        double sum = 0;
        int i;
        double  son = 2.0, mother = 1.0, mid; // 修改
        for (i = 0; i < n; i++) {
            sum += son / mother;
            mid = son;
            son = son + mother;
            mother = mid;
        }
        return sum;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 4月27日
  • 已采纳回答 4月19日
  • 创建了问题 4月19日

悬赏问题

  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题