Java Nested Loop

Understanding Java Nested Loops

When you’re learning Java programming, one of the fundamental concepts you’ll encounter is loops. Loops are used to execute a block of code multiple times, and Java provides several ways to create them: for loops, while loops, and do-while loops. But what happens when you need a loop inside another loop? That’s where nested loops come into play.

In this blog post, we’ll dive deep into Java’s nested loops: what they are, how they work, and some common use cases.

What Are Nested Loops?

A nested loop is simply a loop that exists inside another loop. The outer loop controls the overall number of iterations, and the inner loop executes its code block multiple times for each iteration of the outer loop. Essentially, nested loops allow you to handle more complex, multi-dimensional tasks, such as working with matrices, grids, or other structures that require repeated iterations over multiple dimensions.

Syntax of Nested Loops in Java

The syntax of a nested loop in Java is straightforward. Here’s how you might use a for loop inside another for loop:

for (int i = 0; i < 5; i++) {            // Outer loop
    for (int j = 0; j < 5; j++) {        // Inner loop
        System.out.println("i: " + i + ", j: " + j);
    }
}
Java

In this example:

  • The outer loop (controlled by i) runs 5 times.
  • For each iteration of the outer loop, the inner loop (controlled by j) runs 5 times.
  • This means the inner loop’s code block will execute a total of 25 times (5 x 5), each time with different values of i and j.

How Nested Loops Work

The way nested loops work can be best understood by thinking of them as “layers.” Here’s a breakdown of the flow:

  1. The outer loop begins its first iteration and enters the inner loop.
  2. The inner loop executes completely (from start to finish) for the current iteration of the outer loop.
  3. Once the inner loop completes, the outer loop moves to its next iteration, and the inner loop starts over from the beginning.
  4. This continues until the outer loop finishes all its iterations.

Let’s walk through an example with a simple program that prints out a grid of stars:

public class NestedLoopExample {
    public static void main(String[] args) {
        // Outer loop - controls the rows
        for (int i = 0; i < 5; i++) {
            // Inner loop - controls the columns
            for (int j = 0; j < 5; j++) {
                System.out.print("* ");  // Print a star without a newline
            }
            System.out.println();  // Move to the next line after each row
        }
    }
}
Java

Output:

* * * * * 
* * * * * 
* * * * * 
* * * * * 
* * * * * 
Java

In this program:

  • The outer loop controls the rows (5 rows in total).
  • The inner loop controls the columns (5 columns per row).
  • Every time the inner loop completes, the System.out.println() in the outer loop moves to the next line.

Common Use Cases for Nested Loops

Nested loops are often used in situations where data is organized in a grid, matrix, or multi-dimensional array. Below are a few common use cases:

1. Working with 2D Arrays

In Java, arrays can have multiple dimensions, such as a 2D array (a matrix). To iterate over a 2D array, you’ll typically use nested loops.

Example: Print all elements of a 2D array:

public class ArrayExample {
    public static void main(String[] args) {
        int[][] matrix = {
            {1, 2, 3},
            {4, 5, 6},
            {7, 8, 9}
        };
        
        // Nested loops to iterate through the 2D array
        for (int i = 0; i < matrix.length; i++) {        // Outer loop for rows
            for (int j = 0; j < matrix[i].length; j++) { // Inner loop for columns
                System.out.print(matrix[i][j] + " ");
            }
            System.out.println();  // Move to the next line after each row
        }
    }
}
Java

Output:

1 2 3 
4 5 6 
7 8 9 
Java

2. Generating Patterns

Another common use case for nested loops is generating patterns, like triangles, squares, or more complex shapes. For example, to generate a right-angled triangle:

public class PatternExample {
    public static void main(String[] args) {
        // Outer loop controls the number of rows
        for (int i = 1; i <= 5; i++) {
            // Inner loop controls the number of stars per row
            for (int j = 1; j <= i; j++) {
                System.out.print("* ");
            }
            System.out.println(); // Move to the next line after each row
        }
    }
}
Java

Output:

* 
* * 
* * * 
* * * * 
* * * * * 
Java

3. Nested Loops with Conditional Statements

Sometimes, nested loops are used in conjunction with if conditions to filter or manipulate data during the iteration process. For instance, you could use nested loops to find pairs of numbers that meet a certain condition.

Example: Find pairs of numbers in an array that sum to 10:

public class PairSum {
    public static void main(String[] args) {
        int[] numbers = {1, 3, 4, 6, 7, 9};
        
        // Outer loop for the first number
        for (int i = 0; i < numbers.length; i++) {
            // Inner loop for the second number
            for (int j = i + 1; j < numbers.length; j++) {
                if (numbers[i] + numbers[j] == 10) {
                    System.out.println("Pair found: (" + numbers[i] + ", " + numbers[j] + ")");
                }
            }
        }
    }
}
Java

Output:

Output:

Pair found: (1, 9)
Pair found: (3, 7)
Pair found: (4, 6)
Java

Performance Considerations

Nested loops can quickly lead to performance issues, especially if the number of iterations is large. Each loop adds another level of complexity, so the total time complexity of nested loops can grow exponentially:

  • A single loop has a time complexity of O(n).
  • A nested loop with two loops has a time complexity of O(n^2).
  • More nested loops increase the time complexity further, such as O(n^3) for three nested loops, and so on.

Therefore, when working with nested loops, it’s important to consider performance and efficiency, especially when dealing with large data sets or complex algorithms.


Nested loops are an essential concept in Java and can be incredibly powerful when you need to iterate over multi-dimensional data, generate patterns, or solve more complex problems. By mastering the basics of nested loops, you can significantly enhance your programming skills and tackle a wide range of tasks.

Remember that while nested loops are useful, they can also lead to performance bottlenecks if not used wisely. Always consider the size of the data and whether a more optimized solution exists.