鱼C论坛

 找回密码
 立即注册
查看: 1503|回复: 1

[已解决]为什么这段斐波那契数列不对

[复制链接]
发表于 2023-11-9 16:02:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
int main()
{
        int n,a[20];
        a[0]=1;
        a[1]=1;
        n = 0;
        int b;
        for(n=2;n<20;n++){
                a[n]=a[n-1]+a[n-2];
                b = a[n-1];
                a[n-2]=b;
                a[n-1]=a[n];
        printf("%d ",a[n]);
        }
        return 0;
}
最佳答案
2023-11-9 16:03:14
问题出在循环内部的交换操作。在每次循环中,您将a[n-1]的值赋给了b,然后将b赋给a[n-2],最后将a[n]的值赋给a[n-1]。这样的交换操作是错误的,会导致计算出错误的斐波那契数列。

正确的做法是使用一个临时变量来保存a[n-1]的值,然后再进行交换操作。以下是修正后的代码:

  1. #include <stdio.h>

  2. int main() {
  3.     int n, a[20];
  4.     a[0] = 1;
  5.     a[1] = 1;

  6.     for (n = 2; n < 20; n++) {
  7.         a[n] = a[n - 1] + a[n - 2];
  8.         int temp = a[n - 1];
  9.         a[n - 1] = a[n];
  10.         a[n] = temp;
  11.         printf("%d ", a[n]);
  12.     }

  13.     return 0;
  14. }
复制代码


修正后的代码会正确计算斐波那契数列,并输出结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-9 16:03:14 | 显示全部楼层    本楼为最佳答案   
问题出在循环内部的交换操作。在每次循环中,您将a[n-1]的值赋给了b,然后将b赋给a[n-2],最后将a[n]的值赋给a[n-1]。这样的交换操作是错误的,会导致计算出错误的斐波那契数列。

正确的做法是使用一个临时变量来保存a[n-1]的值,然后再进行交换操作。以下是修正后的代码:

  1. #include <stdio.h>

  2. int main() {
  3.     int n, a[20];
  4.     a[0] = 1;
  5.     a[1] = 1;

  6.     for (n = 2; n < 20; n++) {
  7.         a[n] = a[n - 1] + a[n - 2];
  8.         int temp = a[n - 1];
  9.         a[n - 1] = a[n];
  10.         a[n] = temp;
  11.         printf("%d ", a[n]);
  12.     }

  13.     return 0;
  14. }
复制代码


修正后的代码会正确计算斐波那契数列,并输出结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 03:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表