时间复杂度,Java

请参阅我根据学校示例编写的代码。

public class Test {
public static void main(String [] args)
{
    int number = 0;
    int [] array = new int[number+1];
    array[number] = 0;
    methodName(number,array);
}

public static void methodName(int n,int[] b )
{
    if (n == 0)
    {
        System.out.println(" b is : " + b);
        return;
    }
    else
    {
        b[n-1] = 0;
        methodName(n-1,b);
        b[n-1] = 1;
        methodName(n-1,b);
    }
}
}

我正在尝试计算此代码的最佳和最差情况时间复杂度。 据我了解,最好的情况是O(1)。 而且我很难确定最坏的情况。 else循环中有四个基本操作。 我知道这是一个逐渐增长的函数,我感觉它接近成为O(!n)。

谢谢您的时间。

fc3svsae86 回答:时间复杂度,Java

如果没有从main以外的任何地方调用methodName, 那么它永远是O(1)

本文链接:https://www.f2er.com/3139812.html

大家都在问