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

At Coder Educational DP-J | DP Series(Episode-12)

Longest Palindromic Subsequence

Light OJ-1027 A Dangerous Maze - Tutorial