C语言---循环迭代的方式求第n个斐波那契数

简介: C语言---循环迭代的方式求第n个斐波那契数
#include <stdio.h>
//循环的方法求出第n个斐波那契数
//1 1 2 3 5 8 13 21 34 55
//求第3个数也就是求2,需要进行一次运算
//求第4个数的时候需要运算两次
//求第五个数的时候要运算3次。
//所以求第n个数的时候,要运算n-2次
 
 
int Fib(int n)
{
 
    int a = 1;
    int b = 1;
    int c = 0;
 
 
 
    //n=1或者n=2的时候,可以不进入循环,n是3的时候大于2,就进去运算
    while (n > 2)//仅仅只有当n>2的时候我们才进行计算
    {
        c = a + b;
        a = b;
        b = c;
        n--;//当n是3的时候—1就是2,就不满足循环的条件
    }//当n是4的=时候,c=1+1=2,然后b就变成下一个运算中的a了,
    //第一个运算的c也变成第二个运算中的b了,然后第四个要求的数就是c了,
    //第一次运算的时候运行了一次n--.所以变成了3,在第二次运行的时候再次
    //运行就变成2了,就停止循环了
    return c;
    //当n=1时,不执行循环,直接返回c
    //当n=2时,不执行循环,直接返回c
}
 
 
 
 
int main()
{
    int n = 0;
    scanf_s("%d", &n);
    int r = Fib(n);
    printf("%d", r);
 
    return 0;
}
 
 
 
 
//循环迭代---求第n个斐波那契数
 
int fib(int n)
{
    if (n <= 2)
    {
        return 1;
    }
    int a = 0,b=1,c;
    for (int i = 2; i <= n; i++)
    {
        c = a + b;// 计算新的斐波那契数,即当前的 a 和 b 之和
 
        //下面的两步是将斐波那契数列不断向后面推进
        a = b;// 将 b 的值赋给 a,此时 a 存储 F(n-1)
        b = c;// 将新计算的 c 值赋给 b,此时 b 存储 F(n)
    }
    return b; //此时 b 存储 F(n)
}
 
int main()
{
    int n;
    scanf("%d", &n);
    int ret = fib(n);
    printf("%d", ret);
    return 0;
}
相关文章
|
1月前
|
C语言
初识C语言2——分支语句和循环语句
初识C语言2——分支语句和循环语句
71 5
|
2月前
|
安全 C语言
C语言循环的使用注意点
在C语言中,合理使用循环对于编写高效、安全的代码至关重要。以下是几点建议:确保循环条件正确以避免无限循环;每次迭代时正确更新循环变量;恰当使用`break`和`continue`控制执行流程;注意嵌套循环中的变量作用域;简化循环体内逻辑;根据需求选择合适的循环类型;注意数据类型以避免溢出;保持良好的缩进和注释习惯;减少重复计算以提升性能;确保循环终止条件明确。遵循这些建议,可以提高代码质量和可维护性。
218 88
|
1月前
|
C语言
【c语言】循环语句
循环结构是C语言中用于简化重复操作的重要工具,主要包括while循环、do-while循环和for循环。while循环是最基本的形式,通过不断检查条件来决定是否继续执行循环体。do-while循环则先执行循环体,再检查条件,至少执行一次。for循环逻辑更复杂,但使用频率最高,适合初始化、条件判断和更新变量的集中管理。此外,循环中还可以使用break和continue语句来控制循环的提前终止或跳过当前迭代。最后,循环可以嵌套使用,解决更复杂的问题,如查找特定范围内的素数。
40 6
|
1月前
|
Serverless C语言
C语言控制语句:分支、循环和转向
C语言控制语句:分支、循环和转向
|
1月前
|
算法 编译器 C语言
【C语言】实现猜数字游戏(分支语句与循环语句的运用)
【C语言】实现猜数字游戏(分支语句与循环语句的运用)
|
1月前
|
C语言
教你快速理解学习C语言的循环与分支
教你快速理解学习C语言的循环与分支
17 0
|
1月前
|
小程序 C语言
初识C语言:走近循环
初识C语言:走近循环
|
2月前
|
C语言
【C语言基础考研向】08判断语句与循环语句
本文介绍了C语言中的关键编程概念:首先解析了关系表达式与逻辑表达式的优先级及计算过程;接着详细说明了`if-else`语句的使用方法及其多分支和嵌套应用;然后讲解了`while`循环与`for`循环的语法和注意事项;最后介绍了`continue`和`break`语句在控制循环中的作用和示例代码。
|
1月前
|
编译器 C语言 C++
【C语言】循环语句(语句使用建议)
【C语言】循环语句(语句使用建议)
|
2月前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。