At Coder Educational DP-F | DP Series(Episode-8)

 Problem Description here


Problem: এই প্রব্লেমে আমাদেরকে দুটি স্ট্রিং দেয়া থাকবে। আমাদেরকে স্ট্রিং দুটির Longest Common Subsequence প্রিন্ট করতে হবে। যদি LCS এর লেন্থ বের করতে বলতো তাহলে শুধু ডিপি করা পর্যন্তই সীমাবদ্ধ থাকতো। কিন্তু, এখানে ডিপি সল্যুশন প্রিন্ট করতে হবে। 


Recursive Solution:

১) এই প্রব্লেমের জন্য আমাদের দুটি স্টেট রাখতে হবে। একটি হচ্ছে আমি বর্তমানে প্রথম স্ট্রিং এর কোন পজিশনে আছি এবং অন্যটি হচ্ছে আমি এখন দ্বিতীয় স্ট্রিং এর কোন পজিশনে আছি। 

২) যদি s1[pos1] == s2[pos2] হয় তবে এই ম্যাচটি কাউন্ট করে দুটি স্টেট এর ভ্যালু ১ বাড়িয়ে পরবর্তী ট্রাঞ্জিশনে যাওয়া ই বেটার।

৩) অন্যথায়, একবার pos1 কে বাড়িয়ে দেখবো এবং আবার pos2 কে বাড়িয়ে দেখবো। এবং LCS ম্যাক্সিমাইজ করবো। 


এবার সল্যুশন প্রিন্ট কিভাবে করবো? 

যেকোন রিকার্সিভ ডিপি প্রব্লেমের সল্যুশন প্রিন্ট এর ধাপগুলোঃ

১) হুবহু ডিপি ফাংশনটি কপি করে আরেকটি ফাংশন বানাবো যার রিটার্ণ টাইপ হবে void.

২) বেসকেসে শুধু return লিখবো।

৩) dp[state-1][state-2]...[state-k] != -1 হলে ক্যালকুলেটেড ভ্যালুটি রিটার্ণ করো এই লাইনদুটি বাদ দিবো। 

৪) এখন, যেহেতু আমার ডিপি ফাংশন প্রতিটি ট্রাঞ্জিশনের ভ্যালুই পূর্বে ক্যালকুলেট করে রাখছে সেহেতু প্রব্লেম এর শর্ত অনুযায়ী আমার বর্তমান অবস্থা থেকে কোন অবস্থায় যাওয়া উচিৎ সেটি আমি বলতে পারবো। এবং যেদিকে যাওয়া উচিৎ সেদিকেই যাবো এবং Relevant Value টি প্রিন্ট করবো। 

আশা করি কোড দেখলে বুঝতে পারবে। 




Iterative Solution:

১) ইটারেটিভ ডিপি তে আমাদের dp[pos1][pos2] এর ভ্যালু ক্যালকুলেট করতে dp[pos1+1][pos2+1], dp[pos1+1][pos2], dp[pos1][pos2+1] এর ভ্যালু প্রয়োজন হয়। যেকারণে, pos1=sz1-1 , ... , 1 এবং pos2=sz2-1 , ... , 1 এই অর্ডারে ডিপি ভ্যালু ক্যালকুলেট করবো। 

২) আর সল্যুশন প্রিন্ট অংশ আশা করি কোড দেখলেই বুঝবে। 



Next Episode

Happy Coding

Comments

Trending Post

Light OJ - 1011- Marriage Ceremonies - Tutorial

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

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