*
**
***
****
*****
****
***
**
*
/**
* C program to print mirrored half diamond star pattern
* atnyla.com
*/
#include <stdio.h>
int main()
{
int i, j, N;
int star, spaces;
/* Input number of columns to print from user */
printf("Enter number of columns : ");
scanf("%d", &N);
spaces = N-1;
star = 1;
/* Iterate through rows */
for(i=1; i<N*2; i++)
{
/* Print leading spaces */
for(j=1; j<=spaces; j++)
printf(" ");
/* Print stars */
for(j=1; j<=star; j++)
printf("*");
/* Move to next line */
printf("\n");
if(i < N)
{
star++;
spaces--;
}
else
{
star--;
spaces++;
}
}
return 0;
}
Enter number of columns : 5
*
**
***
****
*****
****
***
**
*
Basic C programming, If else, For loop, Nested loop
*
**
***
****
*****
****
***
**
*
The above pattern is almost similar to half diamond star pattern if you remove leading spaces. Spaces as well as stars in the given pattern are printed in specific fashion. Which is stars are arranged in increasing order from 1 to Nth row. After Nth row stars are printed in decreasing order. Spaces are printed in decreasing order till Nth row. After Nth row spaces are arranged in increasing order. You can point your mouse pointer over the pattern to count total spaces.
Step by step descriptive logic to print mirrored half diamond star pattern.
spaces=N-1 and star=1.N*2-1. The loop structure should look like for(i=1; i. for(j=1; j<=spaces; j++). Inside this loop print single space.for(j=1; j<=stars; j++). Inside this loop print star.First read the algorithm, then study the program code line by line. After that, compare the code with the output and finally go through the explanation. This approach helps learners understand both the logic and the implementation properly.
After understanding this example, try to rewrite the same program without looking at the code. Then change some values or logic and run it again. This helps improve confidence and keeps learners engaged on the page for longer.