At Coder Educational DP-A | DP Series(Episode-1)
কিছু কথাঃ DP Series এ আমি মূলত At Coder Educational DP কন্টেস্টের প্রব্লেমগুলো নিয়ে আলোচনা করবো এবং সেই সাথে ডিপি সল্যুশন প্রিন্ট, ডিপি অপটিমাইজেশনসহ আরো কিছু বিষয় নিয়ে আলোচনা করবো।
এই সিরিজ টি পড়া শুরু করার আগে সবার ব্যাসিক ডিপি সম্পর্কে ধারণা থাকা আবশ্যক।
এজন্য শাফায়েতের ব্লগ থেকে ডাইনামিক প্রোগ্রামিং এর সবগুলো পর্ব পড়ে নেয়ার জন্য অনুরোধ করছি।
Problem Description here
Problem: প্রব্লেমটিতে বলা হয়েছে, আমাদেরকে n টি পাথর দেয়া থাকবে। এবং প্রতিটি পাথরের উচ্চতা দেয়া থাকবে।
একটি ব্যাঙ শুরুতে ১নম্বর পাথরে আছে। ব্যাঙ টি একঘর অথবা দুইঘর জাম্প করতে পারে। অর্থাৎ, i তম পাথর থেকে i+1 or i+2 তম পাথরে যেতে পারে। ith থেকে jth পাথরে যেতে তাকে দুইটি স্টোনের উচ্চতার পার্থক্যের সমান টাকা খরচ করতে হয়।
বের করতে হবে n তম পাথরে পৌঁছাতে তাকে সর্বনিম্ন কত খরচ করতে হবে?
Recursive Solution:
১) এই প্রব্লেমের জন্য আমাদের কয়টি স্টেট লাগবে? ভালোভাবে লক্ষ্য করলে বুঝবে শুধুমাত্র পজিশন ই স্টেট হিসেবে রাখা যথেষ্ট।
২) এরপর, প্রতি পজিশন থেকে আমি একবার একঘর জাম্প করে দেখবো কত খরচ হয়। তারপর, যদি সম্ভব হয় দুইঘর জাম্প দিয়ে দেখবো কত খরচ হয়।
৩) এরপর, মিনিমাম খরচ টি রিটার্ন করে দিবো!
কোডে dp[pos] বলতে বোঝানো হয়েছে, pos তম পজিশন থেকে n তম পজিশনে সর্বনিম্ন কত খরচে যাওয়া যায়।
Iterative Solution:
১) রিকার্সিভ ডিপির কোড দেখলে নিশ্চয়ই বুঝেছো যে, dp[i] এর ভ্যালু বের করার জন্য আমাদের dp[i+1] এবং dp[i+2] এর ভ্যালু এর দরকার হয়। মজার ব্যাপার হলো, রিকার্শন কিন্তু ভবিষ্যৎ দেখতে পারে। সে ভবিষ্যতে গিয়ে এই ভ্যালুগুলো ক্যালকুলেট করে এনে আমাদেরকে দেয়। তারপর, আমরা dp[i] এর ভ্যালু ক্যালকুলেট করতে পারি।
২) কিন্তু, ইটারেশন এর মাধ্যমে ভবিষ্যৎ দেখা সম্ভব নয়। এই পদ্ধতি একটি আপাদমস্তক বাস্তবিক পদ্ধতি। যেকারণে, এই পদ্ধতিতে আমরা dp[n],dp[n-1],dp[n-2],...,dp[1] এই অর্ডারে ভ্যালুগুলো ক্যালকুলেট করে থাকি।
৩) কারণ, এভাবে ক্যালকুলেট করলেই আমার পক্ষে dp[i+1],dp[i+2] এর ভ্যালু জানা সম্ভব যখন কি না আমি ith পজিশনে আছি।
Happy Coding
Comments
Post a Comment