কম্পিউটার

সর্বাধিক ক্যান্ডি আপনি C++ এ বক্স থেকে পেতে পারেন


ধরুন আমাদের n বক্স আছে, এখানে প্রতিটি বক্স ফরম্যাটে দেওয়া আছে যেমন [status, candies, keys, containedBoxes] কিছু সীমাবদ্ধতা আছে −

  • অবস্থা[i]:বাক্স[i] খোলা থাকলে an হয় 1 এবং বাক্স[i] বন্ধ হলে 0 হয়।

  • ক্যান্ডি[i]:বাক্সে ক্যান্ডির সংখ্যা।

  • কী[i]:একটি অ্যারেতে বাক্সের সূচক রয়েছে যা আমরা বাক্সে কী দিয়ে খুলতে পারি।

  • ধারণকারী বক্সগুলি[i]:একটি অ্যারে বাক্সে পাওয়া বাক্সগুলির সূচকগুলি ধারণ করে।

আমরা ইনিশিয়ালবক্স অ্যারেতে দেওয়া কিছু বক্স দিয়ে শুরু করব। আমরা যেকোন খোলা বাক্সে সমস্ত ক্যান্ডি নিতে পারি এবং নতুন বাক্সগুলি খুলতে আমরা এর চাবিগুলি ব্যবহার করতে পারি এবং আমরা এতে যে বাক্সগুলি পাই তাও ব্যবহার করতে পারি৷

উপরে উল্লিখিত এই নিয়মগুলি অনুসরণ করে আমরা সর্বাধিক কতগুলি ক্যান্ডি পেতে পারি তা আমাদের খুঁজে বের করতে হবে৷

সুতরাং, যদি ইনপুট হয় স্ট্যাটাস =[1,0,1,0], ক্যান্ডি =[8,6,5,101], এবং কী =[[], [], [1], []], অন্তর্ভুক্ত বক্স =[ [1,2],[3],[],[]], initialBoxes =[0], তারপর আউটপুট হবে 19। এর কারণ হল আমাদের প্রথমে বক্স 0 দেওয়া হবে। আমরা এতে 8টি ক্যান্ডি এবং বক্স পাব। 1 এবং 2. বক্স 1 খোলা হয়নি এবং আমাদের কাছে এটির জন্য একটি চাবি নেই তাই আমরা বক্স 2 খুলব। আমরা বক্স 2 এ 5টি ক্যান্ডি এবং বক্স 1 এর একটি চাবি পাব। বক্স 1 এ, আপনি 6টি ক্যান্ডি পাবেন এবং বক্স 3 কিন্তু আমরা বক্স 3 এর একটি চাবি খুঁজে পাব না তাই বক্স 3 বন্ধ থাকবে। সংগ্রহ করা ক্যান্ডির মোট সংখ্যা =8 + 5 + 6 =19 ক্যান্ডি।

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

  • উত্তর :=0

  • একটি সারি q

    সংজ্ঞায়িত করুন
  • পরিদর্শন করা, খোলা, hasKey

    সেট সংজ্ঞায়িত করুন
  • আরম্ভ করার জন্য i :=0, যখন i

    • x :=ib[i]

    • পরিদর্শন

      -এ x ঢোকান
    • যদি st[x] 1 এর মত হয়, তাহলে −

      • ans :=ans + cnt[x]

      • খোলাতে x ঢোকান

      • q

        -এ x সন্নিবেশ করান
  • যখন (q খালি নয়), −

    করুন
    • curr :=q এর প্রথম উপাদান

    • q

      থেকে উপাদান মুছুন
    • আরম্ভ করার জন্য i :=0, যখন i

      • x :=k[curr, i]

      • hasKey

        -এ x ঢোকান
      • যদি x খোলা না থাকে এবং x পরিদর্শন না হয়, তাহলে −

        • ans :=ans + cnt[x]

        • q

          -এ x সন্নিবেশ করান
        • খোলাতে x ঢোকান

    • আরম্ভ করার জন্য i :=0, যখন i

      • x :=cb[curr, i]

      • পরিদর্শন

        -এ x ঢোকান
      • যদি x খোলা না থাকে এবং x hasKey তে থাকে বা st[x] 1 এর মত হয়), তাহলে −

        • খোলাতে x ঢোকান

        • ans :=ans + cnt[x]

        • q

          -এ x সন্নিবেশ করান
  • উত্তর ফেরত দিন

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

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
class Solution {
   public:
   int maxCandies(vector<int>& st, vector<int>& cnt,
   vector<vector<int>>& k, vector<vector<int>>& cb, vector<int>& ib) {
      int ans = 0;
      queue<int> q;
      set<int> visited;
      set<int> opened;
      set<int> hasKey;
      for (int i = 0; i < ib.size(); i++) {
         int x = ib[i];
         visited.insert(x);
         if (st[x] == 1) {
            ans += cnt[x];
            opened.insert(x);
            q.push(x);
         }
      }
      while (!q.empty()) {
         int curr = q.front();
         q.pop();
         for (int i = 0; i < k[curr].size(); i++) {
            int x = k[curr][i];
            hasKey.insert(x);
            if (!opened.count(x) && visited.count(x)) {
               ans += cnt[x];
               q.push(x);
               opened.insert(x);
            }
         }
         for (int i = 0; i < cb[curr].size(); i++) {
            int x = cb[curr][i];
            visited.insert(x);
            if (!opened.count(x) && (hasKey.count(x) || st[x] ==
            1)) {
               opened.insert(x);
               ans += cnt[x];
               q.push(x);
            }
         }
      }
      return ans;
   }
};
main(){
   Solution ob;
   vector<int> v = {1,0,1,0}, v1 = {8,6,5,101}, v2 = {0};
   vector<vector<int>> v3 = {{},{},{1},{}}, v4 = {{1,2},{3},{0},{}};
   cout << (ob.maxCandies(v, v1, v3, v4, v2));
}

ইনপুট

{1,0,1,0}, {8,6,5,101}, {{},{},{1},{}}, {{1,2},{3},{0},{}}, {0}

আউটপুট

19

  1. সর্বাধিক বিশপ যা C++ এ N*N চেসবোর্ডে স্থাপন করা যেতে পারে

  2. সর্বাধিক পার্থক্য উপাদান যা C++ এ একটি সেটে যোগ করতে পারে

  3. সর্বাধিক আয়না যা C++ এ নিচ থেকে ডানে আলো স্থানান্তর করতে পারে

  4. আপনি এখন Microsoft থেকে সরাসরি Windows 11 ডিজিটাল লাইসেন্স পেতে পারেন