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

Light OJ - 1011- Marriage Ceremonies - Tutorial

SPOJ - PARSUMS - Nonnegative Partial Sums with Sliding Range Minimum Query

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