java - 在递归算法中计算运行时间

标签 java algorithm recursion runtime divide-and-conquer

练习递归和D&C,一个常见的问题似乎是转换数组:
[a1,a2,a3..an,b1,b2,b3...bn][a1,b1,a2,b2,a3,b3...an,bn]
我按如下方式解决了它(startAa 的开始,startBb 的开始:

private static void shuffle(int[] a, int startA, int startB){  
        if(startA == startB)return;  
        int tmp = a[startB];  
        shift(a, startA + 1, startB);  
        a[startA + 1] = tmp;  
        shuffle(a, startA + 2, startB + 1);  
    }  

    private static void shift(int[] a, int start, int end) {  
        if(start >= end)return;  
        for(int i = end; i > start; i--){  
            a[i] = a[i - 1];   
        }       
    }  

但我不确定运行时是什么。它不是线性的吗?

最佳答案

令算法消耗的时间为T(n),令n=startB-startA

每次递归调用将运行时间减 1(startB-startA 每次调用减一),因此运行时间为 T(n) = T(n-1) + f(n),我们只需要弄清楚f(n)是什么

每次调用的瓶颈是 shift() 操作,它从 startA+1 迭代到 startB,这意味着 n-1 次迭代。

因此,算法的复杂度为T(n) = T(n-1) + (n-1)

但是,这是一个已知的 Theta(n^2) 函数 ( sum of arithmetic progression ) - 算法的时间复杂度为 Theta(N^2),因为初始 startB-startAN(输入的大小)成线性关系。

关于java - 在递归算法中计算运行时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14040778/

相关文章:

c - 确定性位加扰以过滤坐标

ruby - 在多维嵌套数组上调用递归函数的问题

java - 如何使用 Java 代码通过 jboss-cli 命令将 EAR 文件部署到 wildfly-17.0.1 服务器

java - JMeter:获取发布请求 URL 和数据

java - 使用数据库限制应用程序进程的并发执行

c++ - 计算可被 K 整除的子数组

一个大数的N个连续数字的Python总和

java - 从递归中画出一棵基本树?

python - 是否可以使用递归技术编写组合函数?

java - 无法解析 Fragment 类中的方法 registerReceiver(android.content.BroadcastReceiver, android.content.IntentFilter)