斐波那契递归时间和非递归时间的比较

本文探讨了递归和非递归实现斐波那契数列的时间效率差异。通过C语言的time.h库,测量了两种方法在不同数值下的运行时间,特别关注了数值过大可能导致的程序无法运行的问题。
摘要由CSDN通过智能技术生成

 目的主要是为了比较一下递归和非递归的运行时间的差异,但是由于数的限制,当输入的数超出限制了,程序就可能无法运行.

在这里面会使用到C语言库函数time.h

.返回类型为t实际为long

.clock()函数是可以计算从开始执行程序到程序结束的时间的,返回时间是毫秒

.

#include<stdio.h>
#include<time.h>
int main()
{
	clock_t start_time,end_time;
	start_time=clock();//开始时间
	//这里面写要测试的程序
	a=1;b=2;
	c=a+b;
	end_time=clock();//结束时间
	printf("%.2f",(double)(start_time-end_time));
	return 0;
}

比较代码: 

#include<stdio.h>
#include<time.h>
//非递归算法
long Fibno(int n)
{
    if(n==1)
     return 1;
    else if(n==2)
     return 1;
    long f1,f2,f3;
    f1=1,f2=1;
    for(int i=3;i<=n;i++){
        f3=f2+f1;
        f1=f2,f2=f3;
    }
    return f3;
}
//递归算法
long Fib(int n)
{
    if(n==1)
        return 1;
    else if(n==2)
        return 1;
    else
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值