কম্পিউটার

পাইথনে k কর্মী নিয়োগের ন্যূনতম খরচ খুঁজে বের করার প্রোগ্রাম


ধরুন আমাদের প্রতিটি ভিন্ন কর্মীর জন্য গুণ নামক একটি অ্যারে আছে, এবং মজুরি এবং একটি মান কে নামক আরেকটি অ্যারে আছে। i-তম কর্মীর একটি গুণমান[i] এবং একটি ন্যূনতম মজুরি প্রত্যাশা মজুরি[i] আছে। আমরা একটি পেইড গ্রুপ গঠনের জন্য K কর্মীদের নিয়োগ করতে চাই। যখন আমরা K কর্মীদের একটি গ্রুপ নিয়োগ করি, তখন আমাদের অবশ্যই তাদের নিম্নলিখিত নিয়ম অনুসারে অর্থ প্রদান করতে হবে:

  • বেতনভুক্ত গ্রুপের প্রতিটি কর্মীকে তাদের মানের অনুপাতে বেতন দেওয়া উচিত অন্যদের সাথে তুলনা করে।

  • বেতনভুক্ত গোষ্ঠীর প্রতিটি শ্রমিককে অবশ্যই তাদের ন্যূনতম মজুরি প্রত্যাশা অনুযায়ী প্রদান করতে হবে।

উপরোক্ত শর্তগুলি পূরণ করে একটি অর্থপ্রদানকারী গ্রুপ গঠনের জন্য আমাদের সর্বনিম্ন পরিমাণ অর্থ খুঁজে বের করতে হবে।

সুতরাং, যদি ইনপুট গুণমান =[10,22,5], মজুরি =[70,52,30] এবং K =2 এর মত হয়, তাহলে আউটপুট হবে 105.000 কারণ আমরা প্রথম কর্মীকে 70 এবং 35 টাকা দেব। 3য় কর্মী।

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

  • qr :=একটি নতুন তালিকা

  • গুণমান এবং মজুরি থেকে প্রতিটি জোড়ার (q, w) জন্য, করুন

    • qr

      এর শেষে সন্নিবেশ করুন (w/q, q)
  • তালিকাটি সাজান qr

  • cand :=একটি নতুন তালিকা, csum :=0

  • আমি 0 থেকে K - 1 রেঞ্জের জন্য, কর

    • হিপ ক্যান্ডে -qr[i, 1] ঢোকান

    • csum :=csum + qr[i, 1]

  • উত্তর :=csum * qr[K - 1, 0]

  • idx-এর জন্য K রেঞ্জ থেকে মানের আকার, করুন

    • হিপ ক্যান্ডে -qr[i, 1] ঢোকান

    • csum :=csum + qr[idx, 1] + হিপ ক্যান্ড থেকে শীর্ষ উপাদান এবং গাদা থেকে মুছে ফেলুন

    • ans =সর্বনিম্ন উত্তর এবং (csum * qr[idx][0])

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

উদাহরণ

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

import heapq
def solve(quality, wage, K):
   qr = []
   for q, w in zip(quality, wage):
      qr.append([w/q, q])
   qr.sort()

   cand, csum = [], 0
   for i in range(K):
      heapq.heappush(cand, -qr[i][1])
      csum += qr[i][1]
   ans = csum * qr[K - 1][0]

   for idx in range(K, len(quality)):
      heapq.heappush(cand, -qr[idx][1])
      csum += qr[idx][1] + heapq.heappop(cand)
      ans = min(ans, csum * qr[idx][0])
   return ans

quality = [10,22,5]
wage = [70,52,30]
K = 2
print(solve(quality, wage, K))

ইনপুট

[10,22,5], [70,52,30], 2

আউটপুট

105

  1. পাইথনে একটি লাঠি কাটতে ন্যূনতম খরচ খুঁজে বের করার প্রোগ্রাম

  2. পাইথনে একটি ব্যাগে ন্যূনতম বল সীমা খুঁজে বের করার প্রোগ্রাম

  3. পাইথনে ঘর আঁকার জন্য ন্যূনতম খরচ খুঁজে বের করার প্রোগ্রাম

  4. পাইথনে সমস্ত পয়েন্ট সংযোগ করার জন্য সর্বনিম্ন খরচ খুঁজে বের করার প্রোগ্রাম