Knapsack-2 | DP Series(Episode-5)

Problem Description here

Problem:

একটি ঘরে n<=100 টি পণ্য আছে যাদের প্রতিটির দাম Price[i]<=1000 এবং ওজন wt[i]<=1e9। এখন, একজন চোর একটি ব্যাগ নিয়ে সেই ঘরে চুরির উদ্দ্যেশ্যে প্রবেশ করলো যার ধারণ ক্ষমতা capacity<=1e12।
বলতে হবে সর্বোচ্চ কত টাকার পণ্য সে চুরি করতে পারবে? 

Solution:

সাধারণত, ন্যাপস্যাক প্রব্লেমে আমরা পজিশন এবং ক্যাপাসিটি কে স্টেট ধরে লাভের অংক ম্যাক্সিমাইজ করি (বিস্তারিত)। কিন্তু, এই প্রব্লেমে ক্যাপাসিটি অনেক বেশি থাকায় তা স্টেট হিসেবে ধরা যাবে না। 

একটু ভালোভাবে লক্ষ্য করলে দেখবে ক্যাপাসিটি বেশি হলেও পণ্যের সর্বমোট দাম(<= 1e5)। তাহলে, এখন আমি দুটি স্টেট নিয়ে কাজ করতে পারি।
স্টেট-১ঃ পজিশন
স্টেট-২ঃ সর্বমোট লাভ 
অর্থাৎ, প্রতি পজিশন i তে দাঁড়িয়ে i to n পর্যন্ত কত কম ওজনের পণ্য নিয়ে এক্সেক্টলি x পরিমাণ লাভ করা যায় এটা বের করাই আমার কাজ। 
সবশেষে, দেখবো আমার ব্যাগের ক্যাপাসিটির সমান বা কম ওজনের পণ্য নিয়ে সর্বোচ্চ কতটাকা লাভ করা যায়। 


Recursive Solution:


Iterative Solution:







Happy Coding

Comments

Trending Post

LeetCode - Single Number III

At Coder Educational DP-A | DP Series(Episode-1)

GCD of all numbers of given range of the array with point update