গঠনটি হল বিভিন্ন ডেটাটাইপ ভেরিয়েবলের একটি সংগ্রহ, যা একটি একক নামের সিনট্যাক্সের অধীনে একত্রিত।
গঠনগুলির ঘোষণা এবং সূচনা
গঠন ঘোষণার সাধারণ ফর্ম নিম্নরূপ -
datatype member1; struct tagname{ datatype member2; datatype member n; };
এখানে, struct - কীওয়ার্ড
ট্যাগনেম - কাঠামোর নাম নির্দিষ্ট করে
member1, member2 - মেকআপ স্ট্রাকচারের ডেটা আইটেমগুলি নির্দিষ্ট করে।
উদাহরণ
struct book{ int pages; char author [30]; float price; };
স্ট্রাকচার ভেরিয়েবল
গঠন ভেরিয়েবল ঘোষণা করার তিনটি উপায় আছে. তারা নিম্নরূপ -
1) struct book{ int pages; char author[30]; float price; }b; 2) struct{ int pages; char author[30]; float price; }b; 3) struct book{ int pages; char author[30]; float price; }; struct book b;
প্রবর্তন এবং কাঠামো অ্যাক্সেস করা
-
সদস্য অপারেটর (বা) ডট অপারেটর ব্যবহার করে সদস্য এবং একটি কাঠামো পরিবর্তনশীলের মধ্যে সংযোগ স্থাপন করা হয়।
-
সূচনা নিম্নলিখিত উপায়ে করা যেতে পারে -
পদ্ধতি 1
struct book{ int pages; char author[30]; float price; } b = {100, “balu", 325.75};
পদ্ধতি 2
struct book{ int pages; char author[30]; float price; }; struct book b = {100, “balu", 325.75};
পদ্ধতি 3 (সদস্য অপারেটর ব্যবহার করে)
struct book{ int pages; char author[30]; float price; } ; struct book b; b. pages = 100; strcpy (b.author, “balu"); b.price = 325.75;
পদ্ধতি 4 (scanf ব্যবহার করে ফাংশন)
struct book{ int pages; char author[30]; float price; } ; struct book b; scanf (“%d", &b.pages); scanf (“%s", b.author); scanf (“%f", &b. price);
আমরা উপরের কাঠামোর যেকোন একটির বিষয়বস্তু প্রিন্ট করতে পারি মূল পদ্ধতিতে যেমন নীচে দেখানো হয়েছে −
main ( ){ struct book b; clrscr ( ); printf ( "enter no of pages, author, price of book"); scanf ("%d%s%f", &b.pages, b.author, &b.price); printf("Details of book are"); printf("pages =%d, author = %s, price = %f", b.pages, b.author, b.price); getch(); }
উদাহরণ
নিম্নলিখিত কাঠামোর আরেকটি উদাহরণ -
#include<stdio.h> struct aaa{ struct aaa *prev; int i; struct aaa *next; }; main(){ struct aaa abc,def,ghi,jkl; int x=100; abc.i=0; abc.prev=&jkl; abc.next=&def; def.i=1; def.prev=&abc; def.next=&ghi; ghi.i=2;ghi.prev=&def; ghi.next=&jkl; jkl.i=3; jkl.prev=&ghi; jkl.next=&abc; x=abc.next->next->prev->next->i; printf("%d",x); }
আউটপুট
2