কম্পিউটার

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


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

  • জোড় উপাদানের জন্য, এটিকে 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. পাইথন প্রোগ্রামে সন্নিবেশ বাছাই