测量并打印出被装饰函数的执行时间,优化递归函数

定义了一个装饰器timer,它测量并打印出被装饰函数的执行时间。这个装饰器使用了Python的time模块来记录函数开始和结束的时间点,然后计算并输出函数的运行时长。使用@timer语法将这个装饰器应用到了fibonacci函数上,这是一个递归实现的斐波那契数列计算函数。

当调用fibonacci(10)时,timer装饰器会自动捕获函数执行前后的时刻,并计算两者之差,即函数的实际运行时间。然后,它会打印出函数名称以及该函数执行所花费的时间,单位是秒。最后,它返回fibonacci函数的计算结果。

然而,值得注意的是,递归实现的斐波那契数列计算在n较大时效率非常低下,因为它重复计算了许多相同的子问题。在实际应用中,特别是对于较大的n值,通常会采用动态规划或记忆化递归来提高效率。例如,你可以使用一个缓存机制来存储已经计算过的斐波那契数值,避免重复计算。

import time
from functools import lru_cache

# 定义一个装饰器,用于打印函数的执行时间
def timer(func):
    def wrapper(*args, **kwargs):
        start = time.time()
        result = func(*args, **kwargs)
        end = time.time()
        print(f"{func.__name__} took {end - start} seconds to run.")
        return result
    return wrapper

# 使用lru_cache装饰器缓存结果,优化递归函数
@lru_cache(maxsize=None)
def fibonacci(n):
    if n < 2:
        return n
    else:
        return fibonacci(n-1) + fibonacci(n-2)

# 使用@符号将timer装饰器应用到fibonacci函数上
fibonacci = timer(fibonacci)

# 调用fibonacci函数,会自动打印执行时间
fibonacci(10)

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很高兴为您解答。这里给的是一个简单的解决方案:在主函数中定义一个指针变量,该变量指向一维数组中的第一个元素。然后定义一个递归函数,该函数的参数为该指针变量,每次调用该函数时,都将指针变量指向一维数组中的下一个元素。在每次调用该函数时,都将当前元素的值与一个全局变量比较,如果当前元素的值大于该全局变量,则将当前元素的值赋值给该全局变量,并在该函数结束时返回该全局变量的值,以得到一维数组中的最大值。最后,在主函数调用定义的递归函数即可完成对一维数组中最大值的搜索。 ### 回答2: 首先,我们可以将问题分解为两个步骤:找到数组中第一个元素和剩余元素的最大值,然后将其与第一个元素进行比较,找最大值。 假设数组为arr,最大值函数为find_max,我们可以用以下方式定义递归函数: ```c float find_max(float *arr, int size) { // 边界条件,当数组只有一个元素时,直接返回该元素 if (size == 1) { return arr[0]; } // 递归调用,分别找剩余数组的最大值 float max_rest = find_max(arr + 1, size - 1); // 比较第一个元素和剩余数组的最大值,返回较大值 if (arr[0] > max_rest) { return arr[0]; } else { return max_rest; } } ``` 在main函数中,我们可以定义一个测量数据数组,然后调用find_max函数验证结果: ```c int main() { float data[] = {2.5, 3.1, 5.6, 1.7, 4.8}; int size = sizeof(data) / sizeof(float); float max_value = find_max(data, size); printf("数组中的最大值为:%f", max_value); return 0; } ``` 运行程序将得到输结果:数组中的最大值为:5.6。 以上就是一个用递归方式找到测量数据数组最大值的方法,并在main函数中验证的步骤。 ### 回答3: 要找到一组float型的测量数据中的最大值,我们可以使用递归函数来实现。首先,在主函数中定义一个一维数组,并填充测量数据。 接下来,我们定义一个递归函数`findMax`,它的形参为指向浮点数数组的指针和数组的长度。在函数内部,我们首先判断数组的长度是否为1,如果是,则直接返回数组中唯一的元素,作为最大值。如果不是,则将数组分为两部分,分别递归调用`findMax`函数来找到两个部分的最大值。最后,比较这两个最大值,返回较大的一个作为整个数组的最大值。 在主函数中,我们调用`findMax`函数,并将测量数据数组的指针和长度传递给它。然后,将返回的最大值打印来,以验证函数的正确性。 以下是具体的代码实现: ```c #include <stdio.h> float findMax(float* arr, int length) { if (length == 1) { return arr[0]; } int mid = length / 2; float max1 = findMax(arr, mid); float max2 = findMax(arr + mid, length - mid); return (max1 > max2) ? max1 : max2; } int main() { float measurements[] = {1.2, 3.4, 5.6, 2.3, 4.5}; // 测量数据数组 int length = sizeof(measurements) / sizeof(float); // 数组长度 float max = findMax(measurements, length); // 调用递归函数找到最大值 printf("最大值为:%f\n", max); // 打印最大值 return 0; } ``` 以上代码中,我们定义了一个一维数组`measurements`,并填充了测量数据。然后,在主函数中调用`findMax`函数,并将测量数据数组的指针`measurements`和数组长度`length`作为参数传递给它。最后,将返回的最大值打印来。 经过验证,我们可以发现函数的运行结果为5.6,与测量数据数组中最大的元素值相符合,因此可以证明递归函数的功能正确。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值