हमें एक पूर्णांक 'n' दिया गया है और कार्य हेक्सागोनल पैटर्न उत्पन्न करना और अंतिम आउटपुट प्रदर्शित करना है।
उदाहरण
Input-: n=5 Output-:
Input-: n = 4 Output-:
दिए गए कार्यक्रम में हम जिस दृष्टिकोण का उपयोग कर रहे हैं वह इस प्रकार है -
- उपयोगकर्ता से 'n' नंबर डालें
- पूरे पैटर्न को तीन भागों में विभाजित करें अर्थात ऊपरी भाग, मध्य भाग और निचला भाग प्रारंभ लूप i पैटर्न के ऊपरी भाग को i से 0 तक प्रिंट करने के लिए और i को n से कम करने के लिए और i स्टार्ट लूप के मान को बढ़ाते रहें m पैटर्न के मध्य भाग को m से 0 तक और m को n-2 से कम प्रिंट करने के लिए और m के मान को बढ़ाते रहें। 0 और h के मान को घटाते रहें * रिक्त स्थान के साथ प्रिंट करते रहें।
एल्गोरिदम
START Step 1-> declare function to print hexagonal pattern void pattern(int n) Declare and set int len = 2 * n - 1 Loop For int i = 0 and i < n and i++ declare and set int temp = i + n Loop For int k = 0 and k < temp and k++ IF ((k == n + i - 1) || (k == n - i - 1)) print * End Else print space End Print \n End Loop For int m = 0 and m < n - 2 and m++ Loop For int j = 0 and j < len and j++ if (j == 0 || j == len - 1) Print * End Else print space End End Print \n End declare and set int res = n - 1 Loop For int h = res and h >= 0 and h-- declare and set int temp2 = h + n Loop For int k = 0 and k < temp2 and k++ if ((k == n + h - 1) || (k == n - h - 1)) print * End Else print space End End Print \n End End Step 2-> In main() Declare variable int n = 5 call pattern(n) STOP
उदाहरण
#include <stdio.h> //program to print hexagon pattern void pattern(int n) { int len = 2 * n - 1; //for loop for upper part of a pattern for (int i = 0; i < n; i++) { int temp = i + n; for (int k = 0; k < temp; k++) { if ((k == n + i - 1) || (k == n - i - 1)) printf("*"); else printf(" "); } printf("\n"); } //for loop for mid part of a pattern for (int m = 0; m < n - 2; m++) { for (int j = 0; j < len; j++) { if (j == 0 || j == len - 1) printf("*"); else printf(" "); } printf("\n"); } //for loop for lower part of a pattern int res = n - 1; for (int h = res; h >= 0; h--) { int temp2 = h + n; for (int k = 0; k < temp2; k++) { if ((k == n + h - 1) || (k == n - h - 1)) printf("*"); else printf(" "); } printf("\n"); } } int main() { int n = 5; pattern(n); return 0; }
आउटपुट