递归与迭代----经久不衰

本文深入探讨了递归与迭代两种编程技术的区别,包括它们的结构基础、终止条件、问题解决方式以及执行效率的对比。并通过一个具体示例,展示了在实际应用中两者的时间消耗差异。

递归与迭代的区别:

1、递归基于选择结构,迭代基于循环结构。

2、递归通过反复进行函数调用实现循环,迭代是显示的使用一个循环结构。

3、递归在遇到基线条件时终止,迭代是在循环条件为假时结束。

4、递归是不断缩小问题直至达到基线条件,迭代是不断改变计数器变量,直至循环条件为假。

5、递归要不断执行函数调用机制,产生很大的函数调用开销,每次调用都会创建函数的一个副本;迭代同常发生在函数内部,所以反复执行是的开销可以忽略不计。

//总的来说,迭代就是循环,递归就是不断调用自身。

以下是运用迭代与递归实现的打印从1到N 的程序,浙大数据结构课上老师举的例子,用clock()函数计算函数执行时间,判断递归和迭代的执行效果。

#include<stdio.h>
#include<time.h>

void printN1(int n);
void printN2(int n);
int main(void){
    int n;
    double duration1,duration2, start1,start2,stop1, stop2;
    printf("n=");
    scanf_s("%d",&n);
    start2 = clock();
    printN2(n);
    stop2 = clock();
    duration2 = (stop2 - start2) / CLK_TCK;
    printf("循环实现需要的时间为:%f", duration2);


    start1 = clock();
    printN1(n);
    stop1 = clock();
    duration1 = (stop1 - start1) / CLK_TCK;
    printf("递归实现需要的时间为:%f", duration1);

    return 0;
}
void printN1(int n){
    if (n){
        printN1(n - 1);
        printf("%d\n", n);
    }
    return;
}

void printN2(int n){
    int i;
    for (i = 0; i <= n; i++){
        printf("%d\n", i);
    }
    return;
}

//尝试在一个函数中调用两次clock()函数,用不同的stop&start但是结果是时间累加,不知为何,,,单个使用就没有问题,不符合逻辑啊,以后碰到再说。

循环0.015递归0.018

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小菜鸡变形记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值