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

গত পর্বের মতো এই পর্বেও আমরা মেমোরি অপ্টিমাইজেশন দেখবো। 
প্রব্লেমঃ মনে করি, আমাকে একটি n * m গ্রীড দেয়া আছে যেখানে n<=10^4 এবং m<=10^4। গ্রীডের প্রতিটি সেলে দুই ধরণের ক্যারেক্টার থাকতে পারে। '.' মানে ফাঁকা সেল এবং '#' মানে দেয়াল। গ্রীডের (1,1) সেল থেকে গ্রীডের (n,m) সেলে যাওয়ার মোট কয়টি পাথ আছে তা বের করতে হবে। প্রতিটি সেল থেকে আমি নিচে অথবা ডানে মুভ দিতে পারবো। 
এন্সার খুব বড় হতে পারে তাই এন্সার কে 10^9 + 7 দ্বারা মড করতে হবে। 

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

একটু হিসেব করলেই দেখতে পাবা এই কোডে আমার মেমোরি লাগে প্রায় ৫৭২ মেগাবাইট!!!

যদি প্রব্লেমে এর কম মেমোরি দেয় তাহলেই আমার এই সল্যুশন আর কাজ করবে না! তার মানে আমাকে মেমোরি আরো অপ্টিমাইজ করতে হবে। 
এখন, কোডের ২৪ এবং ২৫ নম্বর লাইন যদি দেখো তাহলে দেখবে আমাকে বর্তমান সারির ডিপি ভ্যালু নির্ণয়ের জন্য আগের সারির ডিপি ভ্যালু জানতে হবে। অর্থাৎ, ith সারির জন্য শুধু (i-1)th সারির ভ্যালু জানাই যথেষ্ট। (i-2)th, (i-3)th,....এসব সারি আমার আর কোন কাজে লাগবে না। 

এখন, আগের পর্বটি পড়ে থাকলে নিশ্চয়ই এতোক্ষণে বুঝে গেছো কিভাবে dp[10005][10005] এর পরিবর্তে dp[2][10005] দিয়েই আমাদের প্রব্লেমটা সলভ করা যায়।

এতে, আমাদের মেমোরি লাগবে প্রায় ১৯১ মেগাবাইট!!! হিউজ মেমোরি অপ্টিমাইজড সল্যুশন!!!

এখনো না বুঝলে কোড দেখতে পারোঃ
Suggested Problem: Click here


Happy Coding😃

Comments

Trending Post

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

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

LeetCode - Single Number III