DP Optimization(Part-3) | DP Series(Episode-17)

 এই পর্বে আমরা মূলত প্রিফিক্স সাম এর মাধ্যমে ডিপির টাইম কমপ্লেক্সিটি অপটিমাইজেশন দেখবো। যা অনেক ডিপি প্রব্লেমেই কাজে লাগতে পারে। 


প্রব্লেমঃ

একটি 1*n আকারের গ্রীডের প্রতি সেলে কিছু ভ্যালু a[i] আছে। একটি সেল i থেকে a[i] দূরত্বের মধ্যে সামনে অথবা পিছনের কোন সেলে জাম্প দেয়া যায়। বলতে হবে সেল 1 থেকে সেল n এ এক্সেক্টলি k সংখ্যক জাম্প দিয়ে কতভাবে যাওয়া যায়?

প্রথমেই এই প্রব্লেমের যে সল্যুশন আমাদের মাথায় আসে তা অনেকটা এরকমঃ 


এখন, n<=10^4, k<=10^4 হলে উপরোক্ত সল্যুশন আর কাজ করবে না! এখন, ১২ এবং ১৫ নম্বর লাইনের ফর লুপ এর দিকে ভালো করে লক্ষ্য কর। 
লক্ষ্য করলে বুঝবে যে এই লুপ দুইটির কাজ আমরা প্রিফিক্স সাম ক্যালকুলেট করে O(1)  কমপ্লেক্সিটি তে করতে পারি। তখন কোডটি দেখতে এরকম হবেঃ 

এখন, উপরের সল্যুশন এ আমাদের মেমোরি লাগে প্রায় ৩৮১ মেগাবাইট। অর্থাৎ, MLE খাওয়ার সম্ভাবনা খুবই বেশি। 
আগের দুইটি পর্ব পড়ে থাকলে নিজে নিজে এই সল্যুশনটিকে মেমোরি অপ্টিমাইজ করার চেষ্টা কর। 

মেমোরি অপ্টিমাইজ করার পর সল্যুশনটা দেখতে এরকম হবেঃ 



Happy Coding😀

Comments

Trending Post

DP Optimization (Part-1) | DP Series(Episode-15)

SOS DP | DP Series(Last Episode)

At Coder Educational DP-N | DP Series(Episode-22)