KEMBAR78
Most Asked Pattern Printing Programs | PDF | Software Engineering | Polytopes
0% found this document useful (0 votes)
375 views46 pages

Most Asked Pattern Printing Programs

The document discusses various pattern printing programs in C, C++ and Java. It provides code snippets to print patterns like solid and hollow rectangles, half and full pyramids using stars and numbers, diamond patterns, Pascal's triangle and a hollow diamond inscribed in a rectangle. The patterns demonstrated include solid and hollow shapes, straight and inverted variations, use of stars and numbers, and palindromic structures. Code examples with explanations are given for each pattern type.

Uploaded by

Anant Upadhiyay
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
375 views46 pages

Most Asked Pattern Printing Programs

The document discusses various pattern printing programs in C, C++ and Java. It provides code snippets to print patterns like solid and hollow rectangles, half and full pyramids using stars and numbers, diamond patterns, Pascal's triangle and a hollow diamond inscribed in a rectangle. The patterns demonstrated include solid and hollow shapes, straight and inverted variations, use of stars and numbers, and palindromic structures. Code examples with explanations are given for each pattern type.

Uploaded by

Anant Upadhiyay
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 46

MOST ASKED PATTERN PRINTING PROGRAMS

#1 - Rectangle Pattern Programs in C, C++, Java

Number of rows: 3
Number of columns: 5

* * * * *
* * * * *
* * * * *

Program to print solid rectangular star pattern

/* C program to print solid rectangle star pattern */

#include <stdio.h>

/* Function to print solid rectangle*/

void solid_rectangle(int n, int m)

int i, j;

for (i = 1; i <= n; i++)

{
for (j = 1; j <= m; j++)

printf(“*”);

printf(“n”);

int main()

int rows, columns;

printf(“nEnter the number of rows : “);

scanf(“%d”, &rows);

printf(“nEnter the number of columns : “);

scanf(“%d”, &columns);

printf(“n”);

solid_rectangle(rows, columns);

return 0;

Hollow rectangular star pattern:

Number of rows: 3
Number of columns: 5
* * * * *
* *
* * * * *

Program to print hollow rectangle star pattern

/* C program to print hollow rectangle star pattern */

#include <stdio.h>

/* Function to print hollow rectangle*/

void hollow_rectangle(int n, int m)

int i, j;

for (i = 1; i <= n; i++)

for (j = 1; j <= m; j++)

if (i==1 || i==n || j==1 || j==m)

printf(“*”);

else

printf(” “);

printf(“n”);

int main()

{
int rows, columns;

printf(“nEnter the number of rows : “);

scanf(“%d”, &rows);

printf(“nEnter the number of columns : “);

scanf(“%d”, &columns);

printf(“n”);

hollow_rectangle(rows, columns);

return 0;

}
#2 - Pyramid Pattern Programs in C using stars

Half Pyramid Star Pattern


*
* *
* * *
* * * *
* * * * *
* * * * * *

// C program to print half pyramid pattern using stars


#include <stdio.h>
int main()
{
int i, j,n;
scanf(“%d”,&n);
for(i = 0; i < n; i++)
{
for(j = 0; j <= i; j++)
{
printf(“*”);
}
printf(“\n”);
}
return 0;
}

Inverted Half pyramid


* * * * * *
* * * * *
* * * *
* * *
* *
*

// C program to print inverted half pyramid pattern using stars


#include <stdio.h>
int main()
{
int i, j, n, k = 0;
scanf(“%d”,&n);

for(i = n; i >= 1; –i)


{
for(j = 1; j <= i; ++j)
{
printf(“* “);
}
printf(“\n”);
}

return 0;
}

Full Pyramid Star Pattern


*
* *
* * *
* * * *
* * * * *
* * * * * *

// C program to print full pyramid pattern using stars


#include <stdio.h>
int main()
{
int i, j, n, k = 0;
scanf(“%d”,&n);

for(i = 1; i <= n; ++i, k = 0)


{
for(j = 1; j <= n – i; ++j)
{
printf(” “);
}

while(k != 2 * i-1)
{
printf(“* “);
++k;
}

printf(“\n”);
}

return 0;
}

Hollow Full Pyramid Star Pattern

*
* *
* *
* *
* * * * * * * *

#include <stdio.h>
int main()
{
int n;
scanf(“%d”,&n);
int i, j, k = 0;
for (i = 1; i <= n; i++)
{
for (j = i; j < n; j++) {
printf(” “);
}
while (k != (2 * i – 1)) {
if (k == 0 || k == 2 * i – 2)
printf(“*”);
else
printf(” “);
k++;
;
}
k = 0;
printf(“\n”); // print next row
}
for (i = 0; i < 2 * n – 1; i++) {
printf(“*”);
}
}

Inverted Hollow Full Pyramid


* * * * * *
* *
* *
*

#include <stdio.h>
int main()
{
int n;
scanf(“%d”, &n);
int i, j;
for (i = 1; i <= n; i++) {
for (j = 1; j < i; j++) {
printf(” “);
}

for (j = 1; j <= (n * 2 – (2 * i – 1)); j++) {

if (i == 1 || j == 1 || j == (n * 2 – (2 * i – 1))) {
printf(“*”);
} else {
printf(” “);
}
}
printf(“\n”);
}
}
#3 - Pyramid Pattern Programs in C, C++, Java using
numbers

Half pyramid pattern using numbers


1
1 2
1 2 3
1 2 3 4
1 2 3 4 5

Program to print half pyramid pattern using numbers


/* C program – Half Pyramid Pattern Printing using numbers */
#include
int main()
{
int i, j,n;
scanf(“%d”,&n);
for(i = 1; i <= n; i++)
{
for(j = 1; j <= i; j++)
{
printf(“%d “,j);
}
printf(“\n”);
}
return 0;
}

Inverted half pyramid pattern using numbers


1 2 3 4 5
1 2 3 4
1 2 3
1 2
1

Program to print inverted half pyramid pattern printing


using numbers

/* C program – Pyramid Pattern Printing using numbers */


#include
int main()
{
int i, j,n;
scanf(“%d”,&n);
for(i = 1; i <= n; i++)
{
for(j = i; j <= n; j++)
{
printf(“%d “,j);
}
printf(“\n”);
}
return 0;
}

Hollow half pyramid pattern using numbers


1
1 2
1 3
1 4
1 2 3 4 5

program print hollow inverted half pyramid pattern using numbers */


#include <stdio.h>
int main()
{
int i, j, n, k = 0;
scanf(“%d”,&n);
for(i = 1; i <= n; i++)
{
for(j = i; j <= n; j++)
{
if (i == 1 || j == i || j == n)
printf(“%d”, j);
else
printf(” “);
}
printf(“\n”);
}
return 0;
}
#4 - Palindrome Pyramid Pattern Programs in C using
numbers & Alphabets

Palindrome half pyramid pattern using numbers

Input:
5 (number of rows)

Output:
1
1 2 1
1 2 3 2 1
1 2 3 4 3 2 1
1 2 3 4 5 4 3 2 1

program for Palindrome pyramid pattern printing using numbers */

#include<stdio.h>
#include<stdlib.h>

int main()

int i,j,k,l,n;

printf(“Enter the number of rows : “);

scanf(“%d”,&n);

for(i = 1; i <= n; i++)

for(k = 1; k <= i; k++)

printf(“%d “,k);

for(l = i-1; l >= 1; l–)

printf(“%d “,l);

printf(“\n”);

return 0;

}
#5 - Diamond Pattern Programs in C using stars

Solid Diamond pattern printing using stars

Input: 5

Output:

*
* *
* * *
* * * *
* * * * *
* * * *
* * *
* *
*

/* C program – solid diamond pattern printing using stars */


#include <stdio.h>

int main()
{
int n, c, k, space = 1;

printf(“Enter the number of rows\n”);


scanf(“%d”, &n);

space = n – 1;

for (k = 1; k <= n; k++)


{
for (c = 1; c <= space; c++)
printf(” “);
space–;
for (c = 1; c <= 2*k-1; c++)
printf(“*”);
printf(“\n”);
}
space = 1;

for (k = 1; k <= n – 1; k++)


{
for (c = 1; c <= space; c++)
printf(” “);
space++;
for (c = 1 ; c <= 2*(n-k)-1; c++)
printf(“*”);
printf(“\n”);
}
return 0;
}
#6 - Diamond Pattern Programs in C, C++, Java using
numbers and stars

Half diamond pattern printing using numbers

Input:
34

Output:
3
44
555
6666
555
44
3

Program for half diamond pattern printing using numbers

/* C program for diamond pattern printing using numbers */


#include <stdio.h>

int main()

int i,j,s,N,count=0;

scanf(“%d%d”,&s,&N);

for(i=s;count<4;count++)

for(j=0;j<count+1;j++)

printf(“%d”,i);

printf(“n”);

i=i+1;

for(i=s+N-2;count>0;count–)

for(j=0;j<count-1;j++)

printf(“%d”,i);

printf(“n”);

i=i-1;

return 0;

}
#8 - Pascal's Triangle Pattern Program in C

row 0 =1
row 1 = (0+1), (1+0) = 1, 1
row 2 = (0+1), (1+1), (1+0) = 1, 2, 1
row 3 = (0+1), (1+2), (2+1), (1+0) = 1, 3, 3, 1
row 4 = (0+1), (1+3), (3+3), (3+1), (1+0) = 1, 4, 6, 4, 1
row 5 = (0+1), (1+4), (4+6), (6+4), (4+1),(1+0) = 1, 5, 10, 10, 5, 1
row 6 = (0+1), (1+5), (5+10), (10+10), (10+5), (5+1), (1+0) = 1, 6, 15, 20, 15, 6, 1

The numbers outside Pascal's triangle are all "0". These "0s" are very important for
the triangular pattern to work to form a triangular array. The triangle starts with a
number "1" above, and any new number added below the upper number "1" is just the
sum of the two numbers above, except for the edge, which is all "1".
row 0 =1
row 1 = (0+1), (1+0) = 1, 1
row 2 = (0+1), (1+1), (1+0) = 1, 2, 1
row 3 = (0+1), (1+2), (2+1), (1+0) = 1, 3, 3, 1
row 4 = (0+1), (1+3), (3+3), (3+1), (1+0) = 1, 4, 6, 4, 1
row 5 = (0+1), (1+4), (4+6), (6+4), (4+1),(1+0) = 1, 5, 10, 10, 5, 1
row 6 = (0+1), (1+5), (5+10), (10+10), (10+5), (5+1), (1+0) = 1, 6, 15, 20, 15, 6, 1

Program to print pascal's triangle

// C program to print pascal’s triangle

#include
int main()
{
int rows, coef = 1, space, i, j;
printf(“\nEnter the number of rows : “);
scanf(“%d”,&rows);
printf(“\n”);
for(i=0; i<rows; i++)
{
for(space=1; space <= rows-i; space++)
printf(” “);

for(j=0; j <= i; j++)


{
if (j==0 || i==0)
coef = 1;
else
coef = coef*(i-j+1)/j;

printf(“%4d”, coef);
}
printf(“\n\n”);
}

return 0;
}
#9 - Hollow Diamond Inscribed in a Rectangle

Input: 5
Output:

Solution for diamond inscribed inside rectangle:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n);
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // upper left triangle
printf("*");
else
printf(" ");
if((i + n) <= j) // upper right triangle
printf("*");
else
printf(" ");
}
printf("\n");
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) //bottom left triangle
printf("*");
else
printf(" ");
if(i >= (2 * n - 1) - j) // bottom right triangle
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n;
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // upper left triangle
cout << "*";
else
cout << " ";
if((i + n) <= j) // upper right triangle
cout << "*";
else
cout << " ";
}
cout << "\n";
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) // bottom left triangle
cout << "*";
else
cout << " ";
if(i >= (2 * n - 1) - j) // bottom right triangle
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt();
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // upper left triangle
System.out.print("*");
else
System.out.print(" ");
if((i + n) <= j) // upper right triangle
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) // bottom left triangle
System.out.print("*");
else
System.out.print(" ");
if(i >= (2 * n - 1) - j) // bottom right triangle
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}
#10 - Butterfly Pattern Printing

Input: 5
Output:

Solution for Butterfly Pattern:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n);
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) // upper left triangle
printf("*");
else
printf(" ");
if(i >= (2 * n - 1) - j) // upper right triangle
printf("*");
else
printf(" ");
}
printf("\n");
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // bottom left triangle
printf("*");
else
printf(" ");
if((i + n) <= j) // bottom right triangle
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n;
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) // upper left triangle
cout << "*";
else
cout << " ";
if(i >= (2 * n - 1) - j) // upper right triangle
cout << "*";
else
cout << " ";
}
cout << "\n";
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // bottom left triangle
cout << "*";
else
cout << " ";
if((i + n) <= j) // bottom right triangle
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt();
// upper half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i >= j) // upper left triangle
System.out.print("*");
else
System.out.print(" ");
if(i >= (2 * n - 1) - j) // upper right triangle
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
// bottom half of the pattern
for(i = 0; i < n; i++)
{
for(j = 0; j < (2 * n); j++)
{
if(i + j <= n - 1) // bottom left triangle
System.out.print("*");
else
System.out.print(" ");
if((i + n) <= j) // bottom right triangle
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}

#11 - Diagonal & Sides of a Rectangle

Input: 7 (input should be an odd number only, else the desired output will not be
obtained)
Output:

Solution for Printing the diagonal and sides of a rectangle:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n); // 'n' must be odd
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// left diagonal, right diagonal, top horizontal, bottom horizontal, l
eft vertical, right vertical
if(i == j || i + j == n - 1 || i == 0 || i == n - 1 || j == 0 || j ==
n - 1)
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n; // 'n' must be odd
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// left diagonal, right diagonal, top horizontal, bottom horizontal, left vertical
, right vertical
if(i == j || i + j == n - 1 || i == 0 || i == n - 1 || j == 0 || j == n - 1)
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt(); // 'n' must be odd
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// left diagonal, right diagonal, top horizontal, bottom horizontal, left vertical
, right vertical
if(i == j || i + j == n - 1 || i == 0 || i == n - 1 || j == 0 || j == n - 1)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}
#12 - Diagonal & Sides of a Rhombus/Diamond

Input: 9 (input should be an odd number only, else the desired output will not be
obtained)
Output:

Solution for Printing the diagonal and sides of a Rhombus/Diamond:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n); // ‘n’ must be odd
int num1 = n / 2 * 3;
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, center vertical, upper left diagonal, bottom left diagonal,
upper right diagonal, bottom right diagonal
if(i == n / 2 || j == n / 2 || i + j == n / 2 || i - j == n / 2 || j - i == n / 2
|| i + j == num1)
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n; // ‘n’ must be odd
int num1 = n / 2 * 3;
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, center vertical, upper left diagonal, bottom left diagonal,
upper right diagonal, bottom right diagonal
if(i == n / 2 || j == n / 2 || i + j == n / 2 || i - j == n / 2 || j - i == n / 2
|| i + j == num1)
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt(); // ‘n’ must be odd
int num1 = n / 2 * 3;
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, center vertical, upper left diagonal, bottom left diagonal,
upper right diagonal, bottom right diagonal
if(i == n / 2 || j == n / 2 || i + j == n / 2 || i - j == n / 2 || j - i == n / 2
|| i + j == num1)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}
#13 - Left and Right Arrows

Input: 7 (Here n is the height and width of pattern to be printed)


Output:

Solution for Printing the left arrow & right arrow:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n); // ‘n’ must be odd
int num1 = n / 2 * 3;
// right arrow
printf("Right Arrow\n");
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, upper right diagonal, bottom right diagonal
if(i == n / 2 || j - i == n / 2 || i + j == num1)
printf("*");
else
printf(" ");
}
printf("\n");
}
// left arrow
printf("Left Arrow\n");
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, bottom left diagonal, upper left diagonal
if(i == n / 2 || i - j == n / 2 || i + j == n / 2)
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n; // ‘n’ must be odd
int num1 = n / 2 * 3;
// right arrow
cout << "Right Arrow" << endl;
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, upper right diagonal, bottom right diagonal
if(i == n / 2 || j - i == n / 2 || i + j == num1)
cout << "*";
else
cout << " ";
}
cout << "\n";
}
// left arrow
cout << "Left Arrow" << endl;
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, bottom left diagonal, upper left diagonal
if(i == n / 2 || i - j == n / 2 || i + j == n / 2)
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt(); // ‘n’ must be odd
int num1 = n / 2 * 3;
// right arrow
System.out.println("Right Arrow");
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, upper right diagonal, bottom right diagonal
if(i == n / 2 || j - i == n / 2 || i + j == num1)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
// left arrow
System.out.println("Left Arrow");
for(i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
// center horizontal, bottom left diagonal, upper left diagonal
if(i == n / 2 || i - j == n / 2 || i + j == n / 2)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}
#14 - Rhombus Pattern Program in C, C++, Java

Input: 4
Output:

Solution for Printing a solid and hollow Rhombus:

#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n);
// solid rhombus
printf("Solid Rhombus\n");
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
printf(" "); // leading spaces
}
for(j = 0; j < n; j++)
{
printf("*");
}
printf("\n");
}
// hollow rhombus
printf("Hollow Rhombus\n");
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
printf(" "); // leading spaces
}
for(j = 0; j < n; j++)
{
// upper horizontal, bottom horizontal, left diagonal, right diagonal
if(i == 0 || i == n - 1 || j == 0 || j == n - 1)
printf("*");
else
printf(" ");
}
printf("\n");
}
return 0;
}

C++

#include <iostream>
using namespace std;
int main()
{
int i, j, n;
cin >> n;
// solid rhombus
cout << "Solid Rhombus" << endl;
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
cout << " "; // leading spaces
}
for(j = 0; j < n; j++)
{
cout << "*";
}
cout << "\n";
}
// hollow rhombus
cout << "Hollow Rhombus" << endl;
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
cout << " "; // leading spaces
}
for(j = 0; j < n; j++)
{
// upper horizontal, bottom horizontal, left diagonal, right diagonal
if(i == 0 || i == n - 1 || j == 0 || j == n - 1)
cout << "*";
else
cout << " ";
}
cout << "\n";
}
return 0;
}

Java

import java.util.Scanner;
public class Main
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
int i, j;
int n = sc.nextInt();
// solid rhombus
System.out.println("Solid Rhombus");
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
System.out.print(" "); // leading spaces
}
for(j = 0; j < n; j++)
{
System.out.print("*");
}
System.out.println();
}
// hollow rhombus
System.out.println("Hollow Rhombus");
for(i = 0; i < n; i++)
{
for(j = 0; j < n - i; j++)
{
System.out.print(" "); // leading spaces
for(j = 0; j < n; j++)
{
// upper horizontal, bottom horizontal, left diagonal, right diagonal
if(i == 0 || i == n - 1 || j == 0 || j == n - 1)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}

You might also like