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

求分数序列前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 word样式右侧翻页键消失
  • ¥15 springboot+vue 集成keycloak sso到阿里云
  • ¥15 win7系统进入桌面过一秒后突然黑屏
  • ¥30 backtrader对于期货交易的现金和资产计算的问题
  • ¥15 求C# .net4.8小报表工具
  • ¥15 安装虚拟机时出现问题
  • ¥15 Selenium+docker Chrome不能运行
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到