কম্পিউটার

পাইথনের একটি পরিবারে উত্তরাধিকারের আদেশ খুঁজে বের করার জন্য প্রোগ্রাম


ধরুন, বিভিন্ন প্রজন্মের সদস্যদের নিয়ে একটি পরিবার আছে। যেমন পরিবারে একজন বাবা, তার সন্তান এবং তাদের দাদী রয়েছে। কিন্তু জন্ম ও মৃত্যু প্রতিটি পরিবারেই ঘটে।

পরিবারের সবচেয়ে বড় সদস্যকে প্রধান হিসেবে বিবেচনা করা হয়। সুতরাং, 'প্রধান' সদস্য মারা গেলে, তাদের সরাসরি উত্তরসূরি বা তাদের সন্তানরা প্রধান হয়। আমরা তিনটি ফাংশন বাস্তবায়ন করি, প্রথমটি ব্যবহার করা হয় যখন একটি শিশু পরিবারে জন্ম নেয়। ফাংশনটি পিতামাতার নাম এবং সন্তানের নাম ইনপুট হিসাবে নেয় এবং তাদের রেকর্ডে যুক্ত করে।

দ্বিতীয় ফাংশন ব্যবহার করা হয় যখন একটি মৃত্যু হয়। এটি ইনপুট হিসাবে মৃত পরিবারের সদস্যের নাম নেয় এবং তাদের রেকর্ড থেকে সরিয়ে দেয়।

তৃতীয় ফাংশন উত্তরাধিকারের আদেশ দেয়। উত্তরাধিকারের বর্তমান ক্রমটি যখনই বলা হয় তখন মুদ্রিত হয়৷

সুতরাং, ইনপুট একটি সেট জন্য; আমাদের উত্তরাধিকারের ক্রম খুঁজে বের করতে হবে। সুতরাং, যদি ইনপুটের ক্রম হয় জন্ম, জন্ম, জন্ম, জন্ম, জন্ম, মৃত্যু, উত্তরাধিকার, মৃত্যু, উত্তরাধিকার, তাহলে আউটপুট হবে ['জাচ', 'জেসি' , 'উরসুলা', 'রায়ান', 'থিয়া'] ['জেসি', 'উরসুলা', 'রায়ান', 'থিয়া']

প্রথমে পরিবারের প্রধান হলেন পল৷

তারপর পল যথাক্রমে জ্যাক এবং জেসি নামে সন্তানের জন্ম দেন।

জেসির তখন তিনটি সন্তান ছিল; উরসুলা, রায়ান এবং থিয়া, উরসুলা সবচেয়ে বড় এবং থিয়া সবচেয়ে ছোট।

তারপর পল মারা যায়। উত্তরাধিকারের ক্রম হল ['Zach', 'Jesse', 'Ursula', 'Ryan', 'Thea']।

তারপর জ্যাচ মারা যায়, উত্তরাধিকারের ক্রম হয়ে যায় ['জেসি', 'উরসুলা', 'রায়ান', 'থিয়া']।

এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -

  • পরিবার :=একটি নতুন মানচিত্র যাতে মান হিসাবে তালিকা রয়েছে

  • প্রধান :=পরিবারের বর্তমান প্রধান

  • মৃত :=একটি সেট

  • একটি ফাংশন জন্ম () সংজ্ঞায়িত করুন। এটি p_name, c_name

    নেবে
    • পরিবারের [p_name]

      শেষে c_name ঢোকান
  • একটি ফাংশন ডেথ () সংজ্ঞায়িত করুন। এটি নাম নেবে

    • সেট ডেডে যোগ করুন(নাম)

  • একটি ফাংশন উত্তরাধিকার () সংজ্ঞায়িত করুন। এটি লাগবে

    • উত্তর :=একটি নতুন তালিকা

    • depth_search(head)

    • উত্তর ফেরত দিন

  • একটি ফাংশন depth_search() সংজ্ঞায়িত করুন। এটি বর্তমান লাগবে

    • যদি কারেন্ট মৃত না হয়, তাহলে

      • উত্তরের শেষে বর্তমান সন্নিবেশ করুন

    • পরিবারের প্রতিটি শিশুর জন্য [বর্তমান], করুন

      • গভীরতা_অনুসন্ধান(শিশু)

উদাহরণ

আসুন আরও ভালভাবে বোঝার জন্য নিম্নলিখিত বাস্তবায়ন দেখি

from collections import defaultdict
class Solution:

   def __init__(self, head_name):
      self.family = defaultdict(list)
      self.head = head_name
      self.dead = set()

   def birth(self, p_name, c_name):
      self.family[p_name].append(c_name)

   def death(self, name):
      self.dead.add(name)

   def inheritance(self):
      self.ans = []
      self.depth_search(self.head)
      return self.ans

   def depth_search(self, current):
      if current not in self.dead:
         self.ans.append(current)
      for child in self.family[current]:
         self.depth_search(child)

ob = Solution('Paul')
ob.birth('Paul', 'Zach')
ob.birth('Paul', 'Jesse')
ob.birth('Jesse', 'Ursula')
ob.birth('Jesse', 'Ryan')
ob.birth('Jesse', 'Thea')
ob.death('Paul')
print(ob.inheritance())
ob.death('Zach')
print(ob.inheritance())

ইনপুট

ob = Solution('Paul')
ob.birth('Paul', 'Zach')
ob.birth('Paul', 'Jesse')
ob.birth('Jesse', 'Ursula')
ob.birth('Jesse', 'Ryan')
ob.birth('Jesse', 'Thea')
ob.death('Paul')
print(ob.inheritance())
ob.death('Zach')
print(ob.inheritance())

আউটপুট

['Zach', 'Jesse', 'Ursula', 'Ryan', 'Thea']
['Jesse', 'Ursula', 'Ryan', 'Thea']

  1. পাইথনের প্রত্যেকের দ্বারা গ্রাফটি অতিক্রম করা যায় কিনা তা খুঁজে বের করার প্রোগ্রাম

  2. পাইথনে অধ্যয়নের কার্যকর উপায় খুঁজে বের করার প্রোগ্রাম

  3. পাইথন প্রোগ্রামে একটি ম্যাট্রিক্সের স্থানান্তর খুঁজুন

  4. পাইথন প্রোগ্রামে অ্যারের সমষ্টি খুঁজুন