এই নিবন্ধে, আমরা পাইথন 3.x-এ স্ট্যাক এবং কিউ স্ট্রাকচার সম্পর্কে জানব। বা তার আগে. এখানে আমরা এই ডেটা স্ট্রাকচারের মধ্যে কাজ এবং পরিবর্তন নিয়ে আলোচনা করব -
এর মধ্যে রয়েছে −
- সন্নিবেশ অপারেশন (ধাক্কা, এনকিউ)
- মোছা অপারেশন (পপ, ডিকিউ)
- ডিসপ্লে / ট্রাভার্সিং অপারেশন
পূর্বশর্ত :তালিকা ও তালিকা কার্যক্রম
সম্পর্কিত ডেটা স্ট্রাকচার :তালিকা ম্যানিপুলেশন
সম্পর্কিত ছবি

স্ট্যাক
স্ট্যাকগুলিতে, বস্তুগুলি একে অপরের উপর সংরক্ষণ করা হয় এবং এই বস্তুগুলি আগমনের বিপরীত ক্রমে সরানো হয় অর্থাৎ LIFO ধারণা অনুসরণ করা হয়। LIFO মানে লাস্ট ইন ফার্স্ট আউট টাইপ বিন্যাস স্ট্যাক ডেটা স্ট্রাকচারে অনুসরণ করা হয়।
একটি স্ট্যাকের উপর ক্রিয়াকলাপ -
- এলিমেন্টের সংযোজন/সংযোজন:এটি যোগ করা আইটেমের সংখ্যার দ্বারা স্ট্যাকের আকার বৃদ্ধি করে এবং সংযোজন উপরের প্রান্তে অর্থাৎ স্ট্যাকের শীর্ষে ঘটে।
- এলিমেন্টের মুছে ফেলা / অপসারণ - এর মধ্যে দুটি শর্ত জড়িত - যদি স্ট্যাকটি খালি থাকে তবে মুছে ফেলার জন্য কোনো উপাদান উপলব্ধ নেই, যেমন আন্ডারফ্লো স্ট্যাকের মধ্যে ঘটে বা যদি স্ট্যাকের মধ্যে কিছু উপাদান থাকে তাহলে শীর্ষে উপস্থিত উপাদানটি সরানো হবে . এটি সরানো উপাদানের সংখ্যা দ্বারা স্ট্যাকের আকার হ্রাস করে।
- ট্র্যাভার্সিং/প্রদর্শন − এর মধ্যে স্ট্যাকের প্রতিটি উপাদান পরিদর্শন করা এবং স্ক্রিনে প্রদর্শন করা জড়িত৷
আমরা পিকের একটি অতিরিক্ত কার্যকারিতাও সন্নিবেশ করতে পারি যেমন স্ট্যাকের শীর্ষে মান পুনরুদ্ধার করা।
স্ট্যাকের বৈশিষ্ট্য
- সন্নিবেশ ক্রম সংরক্ষিত।
- স্ট্যাকে ডুপ্লিকেসি অনুমোদিত৷ ৷
- অনুরূপ ডেটা-টাইপ স্টোরেজ।
- পার্সিং অপারেশনে অত্যন্ত উপযোগী।
উদাহরণ কোড
def isEmpty(stk): # checks whether the stack is empty or not
if stk==[]:
return True
else:
return False
def Push(stk,item): # Allow additions to the stack
stk.append(item)
top=len(stk)-1
def Pop(stk):
if isEmpty(stk): # verifies whether the stack is empty or not
print("Underflow")
else: # Allow deletions from the stack
item=stk.pop()
if len(stk)==0:
top=None
else:
top=len(stk)
print("Popped item is "+str(item))
def Display(stk):
if isEmpty(stk):
print("Stack is empty")
else:
top=len(stk)-1
print("Elements in the stack are: ")
for i in range(top,-1,-1):
print (str(stk[i]))
# executable code
if __name__ == "__main__":
stk=[]
top=None
Push(stk,1)
Push(stk,2)
Push(stk,3)
Push(stk,4)
Pop(stk)
Display(stk) উপরের কোডটি পাইথন 3.x-এ স্ট্যাক কার্যকারিতা প্রয়োগ করে। বা তার আগে. আমরা একাধিক if-else স্টেটমেন্ট ব্যবহার করে ব্যবহারকারীকে পছন্দ প্রদান করে একটি মেনু-চালিত প্রোগ্রাম তৈরি করতে পারি। উভয় ক্ষেত্রেই স্ট্যাক তৈরির ধারণা একই থাকে।
নীচে দেখানো পর্দা উপরের প্রোগ্রাম দ্বারা উত্পাদিত আউটপুট চিত্রিত. আমরা ব্যবহারকারী-ভিত্তিক ইনপুট সিস্টেমের জন্য ইনপুট() ফাংশন ব্যবহার করতে পারি (এখানে আমি স্ট্যাটিক ইনপুট প্রয়োগ করেছি)
আউটপুট
Popped item is 4 Elements in the stack are: 3 2 1
সারি
স্ট্যাকগুলিতে, বস্তুগুলি একের পর এক সংরক্ষণ করা হয়, এবং এই বস্তুগুলি আগমনের ক্রমে সরানো হয় অর্থাৎ FIFO ধারণা অনুসরণ করা হয়। FIFO মানে ফার্স্ট ইন ফার্স্ট আউট টাইপ বিন্যাস সারি ডেটা স্ট্রাকচারে অনুসরণ করা হয়।
একটি সারিতে ক্রিয়াকলাপ
-
উপাদানের সংযোজন/সংযোজন − এটি যোগ করা আইটেমের সংখ্যা দ্বারা সারির আকার বৃদ্ধি করে এবং সংযোজনটি পিছনের প্রান্তে অর্থাৎ সারির পিছনের অংশে ঘটে।
-
উপাদান মুছে ফেলা / অপসারণ - এর মধ্যে দুটি শর্ত রয়েছে - যদি সারিটি খালি থাকে তবে মুছে ফেলার জন্য কোনও উপাদান উপলব্ধ নেই যেমন সারিতে আন্ডারফ্লো ঘটে বা যদি সারিতে কিছু উপাদান উপস্থিত থাকে তবে সামনে উপস্থিত উপাদানটি সরানো হয়। এটি সরানো উপাদানের সংখ্যা দ্বারা স্ট্যাকের আকার হ্রাস করে।
-
ট্রাভার্সিং /ডিসপ্লে করা - এর মধ্যে স্ট্যাকের প্রতিটি উপাদান পরিদর্শন করা এবং স্ক্রিনে প্রদর্শন করা জড়িত৷
আমরা পিকের একটি অতিরিক্ত কার্যকারিতাও সন্নিবেশ করতে পারি যেমন সারির পিছনে/শেষে মান পুনরুদ্ধার করা।
সারির বৈশিষ্ট্য
- সন্নিবেশ ক্রম সংরক্ষিত।
- সারিতে ডুপ্লিকেসি অনুমোদিত।
- অনুরূপ ডেটা-টাইপ স্টোরেজ।
- সিপিইউ টাস্ক অপারেশন পার্স করার ক্ষেত্রে অত্যন্ত উপযোগী।
উদাহরণ কোড
#Adding elements to queue at the rear end
def enqueue(data):
queue.insert(0,data)
#Removing the front element from the queue
def dequeue():
if len(queue)>0:
return queue.pop()
return ("Queue Empty!")
#To display the elements of the queue
def display():
print("Elements on queue are:");
for i in range(len(queue)):
print(queue[i])
# executable code
if __name__=="__main__":
queue=[]
enqueue(5)
enqueue(6)
enqueue(9)
enqueue(5)
enqueue(3)
print("Popped Element is: "+str(dequeue()))
display() উপরের কোডটি পাইথন 3.x-এ সারির কার্যকারিতা প্রয়োগ করে। বা তার আগে. আমরা একাধিক if-else স্টেটমেন্ট ব্যবহার করে ব্যবহারকারীকে পছন্দ প্রদান করে একটি মেনু-চালিত প্রোগ্রাম তৈরি করতে পারি। উভয় ক্ষেত্রেই সারি তৈরির ধারণা একই থাকে।
নীচে দেখানো পর্দা উপরের প্রোগ্রাম দ্বারা উত্পাদিত আউটপুট চিত্রিত. আমরা ব্যবহারকারী-ভিত্তিক ইনপুট সিস্টেমের জন্য ইনপুট() ফাংশন ব্যবহার করতে পারি (এখানে আমি স্ট্যাটিক ইনপুট প্রয়োগ করেছি)
আউটপুট
Popped item is: 5 Elements on queue are: 3 5 9 6
উপসংহার
এই নিবন্ধে, আমরা পাইথন 3.x-এ স্ট্যাক ও কিউ ডেটা স্ট্রাকচার কীভাবে বাস্তবায়ন করতে হয় তা শিখেছি। বা তার আগে. আপনি অন্য কোনো প্রোগ্রামিং ভাষায় স্ট্যাক/কিউ ডিটেক্টর প্রোগ্রাম বাস্তবায়ন করতে একই অ্যালগরিদম প্রয়োগ করতে পারেন।