কম্পিউটার

অ্যারে ব্যবহার করে স্ট্যাক বাস্তবায়নের জন্য C++ প্রোগ্রাম


একটি স্ট্যাক হল একটি বিমূর্ত ডেটা কাঠামো যা উপাদানগুলির একটি সংগ্রহ ধারণ করে। স্ট্যাক LIFO মেকানিজম প্রয়োগ করে অর্থাৎ শেষে যে উপাদানটি পুশ করা হয় তা প্রথমে পপ আউট করা হয়। স্ট্যাকের কিছু নীতিগত ক্রিয়াকলাপ হল −

  • পুশ - এটি স্ট্যাকের শীর্ষে একটি ডেটা মান যোগ করে।

  • পপ - এটি স্ট্যাকের উপরে ডেটা মান সরিয়ে দেয়

  • পিক - এটি স্ট্যাকের শীর্ষ ডেটা মান প্রদান করে

একটি প্রোগ্রাম যা অ্যারে ব্যবহার করে একটি স্ট্যাক প্রয়োগ করে নিম্নরূপ দেওয়া হয়।

উদাহরণ

#include <iostream>
using namespace std;
int stack[100], n=100, top=-1;
void push(int val) {
   if(top>=n-1)
   cout<<"Stack Overflow"<<endl;
   else {
      top++;
      stack[top]=val;
   }
}
void pop() {
   if(top<=-1)
   cout<<"Stack Underflow"<<endl;
   else {
      cout<<"The popped element is "<< stack[top] <<endl;
      top--;
   }
}
void display() {
   if(top>=0) {
      cout<<"Stack elements are:";
      for(int i=top; i>=0; i--)
      cout<<stack[i]<<" ";
      cout<<endl;
   } else
   cout<<"Stack is empty";
}
int main() {
   int ch, val;
   cout<<"1) Push in stack"<<endl;
   cout<<"2) Pop from stack"<<endl;
   cout<<"3) Display stack"<<endl;
   cout<<"4) Exit"<<endl;
   do {
      cout<<"Enter choice: "<<endl;
      cin>>ch;
      switch(ch) {
         case 1: {
            cout<<"Enter value to be pushed:"<<endl;
            cin>>val;
            push(val);
            break;
         }
         case 2: {
            pop();
            break;
         }
         case 3: {
            display();
            break;
         }
         case 4: {
            cout<<"Exit"<<endl;
            break;
         }
         default: {
            cout<<"Invalid Choice"<<endl;
         }
      }
   }while(ch!=4);
   return 0;
}

আউটপুট

1) Push in stack
2) Pop from stack
3) Display stack
4) Exit

Enter choice: 1
Enter value to be pushed: 2
Enter choice: 1
Enter value to be pushed: 6
Enter choice: 1
Enter value to be pushed: 8
Enter choice: 1
Enter value to be pushed: 7
Enter choice: 2
The popped element is 7
Enter choice: 3
Stack elements are:8 6 2
Enter choice: 5
Invalid Choice
Enter choice: 4
Exit

উপরের প্রোগ্রামে, পুশ() ফাংশনটি স্ট্যাকের মধ্যে পুশ করার জন্য আর্গুমেন্ট ভ্যাল অর্থাৎ মান নেয়। যদি একটি শীর্ষ n এর থেকে বড় বা সমান হয়, তাহলে একটি স্ট্যাকের মধ্যে কোন স্থান নেই এবং ওভারফ্লো মুদ্রিত হয়। অন্যথায়, ভ্যাল স্ট্যাকের মধ্যে ধাক্কা দেওয়া হয়। এর জন্য কোড স্নিপেট নিম্নরূপ।

void push(int val) {
   if(top>=n-1)
   cout<<"Stack Overflow"<<endl;
   else {
      top++;
      stack[top]=val;
   }
}

পপ() ফাংশন স্ট্যাকের সর্বোচ্চ মান পপ করে, যদি কোনো মান থাকে। স্ট্যাক খালি হলে আন্ডারফ্লো প্রিন্ট করা হয়। এটি নিম্নরূপ দেওয়া হল।

void pop() {
   if(top<=-1)
   cout<<"Stack Underflow"<<endl;
   else {
      cout<<"The popped element is "<< stack[top] <<endl;
      top--;
   }
}

প্রদর্শন() ফাংশন স্ট্যাকের সমস্ত উপাদান প্রদর্শন করে। এটি করার জন্য একটি লুপ ব্যবহার করে। যদি স্ট্যাকের মধ্যে কোন উপাদান না থাকে, তাহলে স্ট্যাক খালি মুদ্রিত হয়। এটি নীচে দেওয়া হল৷

void display() {
   if(top>=0) {
      cout<<"Stack elements are:";
      for(int i=top; i>=0; i--)
      cout<<stack[i]<<" ";
      cout<<endl;
   }else
   cout<<"Stack is empty";
}

ফাংশন main() ব্যবহারকারীকে একটি পছন্দ প্রদান করে যদি তারা স্ট্যাকটি পুশ, পপ বা প্রদর্শন করতে চায়। ব্যবহারকারীর প্রতিক্রিয়া অনুসারে, উপযুক্ত ফাংশনকে বলা হয় সুইচ ব্যবহার করে। যদি ব্যবহারকারী একটি অবৈধ প্রতিক্রিয়া প্রবেশ করে, তাহলে সেটি মুদ্রিত হয়। এর জন্য কোড স্নিপেট নিচে দেওয়া হল।

int main() {
   int ch, val;
   cout<<"1) Push in stack"<<endl;
   cout<<"2) Pop from stack"<<endl;
   cout<<"3) Display stack"<<endl;
   cout<<"4) Exit"<<endl;
   do {
      cout<<"Enter choice: "<<endl;
      cin>>ch;
      switch(ch) {
         case 1: {
            cout<<"Enter value to be pushed:"<<endl;
            cin>>val;
            push(val);
            break;
         }
         case 2: {
            pop();
            break;
         }
         case 3: {
            display();
            break;
         }
         case 4: {
            cout<<"Exit"<<endl;
            break;
         }
         default: {
            cout<<"Invalid Choice"<<endl;
         }
      }
   }while(ch!=4);
   return 0;
}

  1. লিঙ্ক করা তালিকা ব্যবহার করে সারি বাস্তবায়নের জন্য C++ প্রোগ্রাম

  2. অ্যারে ব্যবহার করে সারি বাস্তবায়নের জন্য C++ প্রোগ্রাম

  3. লিঙ্ক করা তালিকা ব্যবহার করে স্ট্যাক বাস্তবায়নের জন্য C++ প্রোগ্রাম

  4. সাজানো অ্যারে বাস্তবায়নের জন্য C++ প্রোগ্রাম