'What would be the time complexity of this two nested loops

given:

public void trash(int n){
    int i =n;
    while (i > 0){
        for (int j = 0; j < n; j++) {
            System.out.println("*");
            i = i/2;
        }
    }
}

I'm might argue that the time complexity for this operation is linear because comparing i > 0 would be constant and the for loop inside would be linear. Therefore give a total of linear time.

But in my head, i still think the operation is quadratic.

Could anyone please give me a clearer explanation of the complexities on nested loops. Thanks



Solution 1:[1]

As written, the outer loop here isn't really doing anything, since i is decremented to 0 inside the inner loop. The while loop will only execute one time. The body of the for loop will execute n times, so the algorithm is O(n).

If you moved i = i/2; to run after the for loop body, the while loop would execute log(n) times, so the algorithm would be O(n * log(n)).

Solution 2:[2]

The total cost of the algorithm is O(n).

More specifically, the for loop has n iterations, and each iteration takes a constant amount of time. (By the way, after log n of these n iterations, i would have reached 0. For the remaining n - log n iterations, i continues to be equal to 0. The print statement is executed during each of these n iterations.) So, the total cost of the for loop is O(n). At the end of these n iterations, i is 0, and so the while loop exits after the first iteration.

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1
Solution 2 Ashwin Ganesan