কম্পিউটার টিউটোরিয়াল

পাইথনে অ্যারেতে বিচ্যুতি কমানোর জন্য প্রোগ্রাম


ধরুন আমরা একটি অ্যারে সংখ্যা আছে. আমরা অ্যারের যেকোন উপাদানে যে কোনো সংখ্যক বার দুই ধরনের অপারেশন করতে পারি

  • জোড় উপাদানের জন্য, এটিকে 2 দ্বারা ভাগ করুন

  • বিজোড় উপাদানের জন্য, এটিকে 2 দ্বারা গুণ করুন।

এখন অ্যারের বিচ্যুতি হল অ্যারের যেকোনো দুটি উপাদানের মধ্যে সর্বোচ্চ পার্থক্য। আমাদের কিছু সংখ্যক অপারেশন করার পর অ্যারের সর্বনিম্ন বিচ্যুতি খুঁজে বের করতে হবে। সুতরাং, যদি ইনপুটটি সংখ্যার মত হয় =[6,3,7,22,5], তাহলে আউটপুট হবে 5 কারণ আমরা আমাদের অ্যারে তৈরি করতে পারি। একটি অপারেশন [6,6,7,22,5] এবং দ্বিতীয় অপারেশন [6,6,7,22,10], এবং আরেকটি অপারেশন [6,6,7,11,10], এখন বিচ্যুতি হল 11- ৬ =৫।

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

  • তালিকার সংখ্যাগুলি সাজান

  • max_v :=সংখ্যার সর্বোচ্চ উপাদান

  • min_v :=সংখ্যার সর্বনিম্ন উপাদান

  • হিপিফাই সংখ্যা

  • res :=max_v - min_v

  • যখন সংখ্যা [0] বিজোড় হয়, কর

    • v :=হিপ কিউ সংখ্যা থেকে পোপ করা উপাদান

    • v :=2 * v

    • হিপ কিউ সংখ্যায় ভি সন্নিবেশ করান

    • min_v :=সংখ্যা[0]

    • max_v :=সর্বাধিক v এবং max_v

    • res :=ন্যূনতম res এবং (max_v - min_v)

  • সংখ্যা :=n এবং ঋণাত্মক ক্রমে সমস্ত সংখ্যার একটি তালিকা

  • heapify হিপ সারি সংখ্যা

  • সংখ্যা[0] জোড় হলে, করুন

    • v :=-(হিপ সারি সংখ্যা থেকে পোপ করা উপাদান)

    • v :=(v/2)

      এর ভাগফল
    • হিপ কিউ সংখ্যায় -v সন্নিবেশ করুন

    • max_v :=-সংখ্যা[0]

    • min_v :=সর্বনিম্ন min_v এবং v

    • res :=ন্যূনতম res এবং (max_v - min_v)

  • রিটার্ন রিটার্ন

উদাহরণ

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

import heapq
def solve(nums):
   nums.sort()
   max_v,min_v = nums[-1],nums[0]
   heapq.heapify(nums)
   res = max_v-min_v
   while nums[0]%2==1:
      v = heapq.heappop(nums)
      v = 2 * v
      heapq.heappush(nums, v)
      min_v = nums[0]
      max_v = max(v, max_v)
      res = min(res, max_v - min_v)

   nums = [-n for n in nums]
   heapq.heapify(nums)
   while nums[0]%2==0:
      v = -heapq.heappop(nums)
      v = v // 2
      heapq.heappush(nums, -v)
      max_v = -nums[0]
      min_v = min(min_v,v)
      res = min(res, max_v - min_v)

   return res

nums = [6,3,7,22,5]
print(solve(nums))

ইনপুট

[6,3,7,22,5]

আউটপুট

5

  1. গণনা সাজানোর জন্য পাইথন প্রোগ্রাম

  2. অ্যারে রোটেশনের জন্য পাইথন প্রোগ্রাম

  3. অ্যারের যোগফল খুঁজে পেতে পাইথন প্রোগ্রাম

  4. পাইথন প্রোগ্রামে সন্নিবেশ বাছাই