Bucle anidado significa una sentencia de bucle dentro de otra sentencia de bucle. Es por eso que los bucles anidados también se denominan » bucle dentro del bucle «.
Sintaxis para el bucle For anidado:
for ( initialization; condition; increment ) { for ( initialization; condition; increment ) { // statement of inside loop } // statement of outer loop }
Sintaxis para el ciclo while anidado:
while(condition) { while(condition) { // statement of inside loop } // statement of outer loop }
Sintaxis del bucle Do-While anidado:
do{ do{ // statement of inside loop }while(condition); // statement of outer loop }while(condition);
Nota: No existe una regla que indique que un bucle debe estar anidado dentro de su propio tipo. De hecho, puede haber cualquier tipo de bucle anidado dentro de cualquier tipo y en cualquier nivel.
Sintaxis:
do{ while(condition) { for ( initialization; condition; increment ) { // statement of inside for loop } // statement of inside while loop } // statement of outer do-while loop }while(condition);
A continuación se muestran algunos ejemplos para demostrar el uso de bucles anidados:
Ejemplo 1: el programa siguiente utiliza un bucle for anidado para imprimir una array 2D.
Java
// Java program to print the elements of // a 2 D array or matrix import java.io.*; class GFG { public static void print2D(int mat[][]) { // Loop through all rows for (int i = 0; i < mat.length; i++) { // Loop through all elements of current row for (int j = 0; j < mat[i].length; j++) System.out.print(mat[i][j] + " "); System.out.println(); } } public static void main(String args[]) throws IOException { int mat[][] = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 }, { 9, 10, 11, 12 } }; print2D(mat); } }
1 2 3 4 5 6 7 8 9 10 11 12
Ejemplo 2: El siguiente programa usa un bucle for anidado para imprimir todos los factores primos de un número.
Java
// Java program to print all prime factors import java.io.*; import java.lang.Math; class GFG { // A function to print all prime factors // of a given number n public static void primeFactors(int n) { // Print the number of 2s that divide n while (n % 2 == 0) { System.out.print(2 + " "); n /= 2; } // n must be odd at this point. So we can // skip one element (Note i = i +2) for (int i = 3; i <= Math.sqrt(n); i += 2) { // While i divides n, print i and divide n while (n % i == 0) { System.out.print(i + " "); n /= i; } } // This condition is to handle the case when // n is a prime number greater than 2 if (n > 2) System.out.print(n); } public static void main(String[] args) { int n = 315; primeFactors(n); } }
3 3 5 7