Diamond Number-Star Pattern (Sandwich Inverted)
Understanding the Problem
The goal is to print a diamond-shaped pattern where numbers are printed in decreasing order in the upper half, followed by a repeated minimum row, and then increasing order in the lower half. Each number is followed by a star except for the last number in each row.
Pattern Explanation
The pattern consists of three parts: the upper half, the repeated minimum row, and the lower half.
4*4*4*4
3*3*3
2*2
1
1
2*2
3*3*3
4*4*4*4
            
            Observations:
- The pattern consists of 7 rows.
- Numbers decrement from 4 to 1 in the upper half.
- The minimum row (1) is repeated once.
- Each number is followed by a '*', except the last number in each row.
- The lower half mirrors the upper half, incrementing from 1 to 4.
Algorithm
The pattern follows these steps:
- Initialize a variable to determine the maximum number (N).
- Loop through rows from N down to 1 to print the upper half of the diamond.
- For each row, loop through columns (up to the current row number) and print the current row number.
- Print the number followed by '*' except for the last number in the row.
- After completing the upper half, print the minimum row (1) again.
- Loop through rows from 1 to N to print the lower half of the diamond.
- Repeat steps 3 and 4 for the lower half.
- Move to the next line after printing each row.
Method 1: Using Nested Loops
This method uses two loops to print the pattern.
public class DiamondNumberStarPatternSandwichInverted {
    public static void main(String[] args) {
        int n = 4;  // Maximum number for the diamond pattern
        // Loop to print the upper half of the diamond
        for (int i = n; i >= 1; i--) {  // Loop for each row
            for (int j = 1; j <= i; j++) {  // Loop for each column in the current row
                System.out.print(i);  // Print the current row number
                if (j < i) System.out.print("*");  // Print '*' if not the last number in the row
            }
            System.out.println();  // Move to the next line after each row
        }
        // Print the minimum row again
        System.out.println("1");  // Print the minimum number
        // Loop to print the lower half of the diamond
        for (int i = 1; i <= n; i++) {  // Loop for each row
            for (int j = 1; j <= i; j++) {  // Loop for each column in the current row
                System.out.print(i);  // Print the current row number
                if (j < i) System.out.print("*");  // Print '*' if not the last number in the row
            }
            System.out.println();  // Move to the next line after each row
        }
    }
}
            
            Output:
4*4*4*4
3*3*3
2*2
1
1
2*2
3*3*3
4*4*4*4