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

Toph - Birthday Present Tutorial

DP Optimization(Part-2) | DP Series(Episode-16)

All pair GCD Sum