At Coder Educational DP-K | DP Series(Episode-13)

 Problem Description here


Problem: এই প্রব্লেমে দুইজন প্লেয়ার একটি গেম খেলবে। যেটা হবেঃ

একটি পাথরের স্তূপ আছে যেখানে K সংখ্যক পাথর আছে। এবং n টি সংখ্যার একটি অ্যারে দেয়া আছে। প্রথম চাল দিবে ১ম জন, ২য় চাল ২য় জন, ৩য় চাল ১ম জন, ৪র্থ চাল ২জন, এভাবে খেলা চলতে থাকবে।

প্রতি চালে একজন প্লেয়ার অ্যারে থেকে যেকোন একটি সংখ্যা নিবে এবং এক্সেক্টলি ততোগুলো পাথর স্তূপ থেকে ফেলে দিবে। যদি কোন প্লেয়ার তার চালে কোন পাথরই না ফেলতে পারে তবে সে হারবে। 

বলতে হবে, দুইজন প্লেয়ারই অপ্টিমালি খেললে কে জিতবে? 


Recursive Solution: 

১) এই প্রব্লেমে আমাদের স্টেট নিতে হবে দুটি।

    স্টেট-১ঃ বর্তমানে স্তুপে কয়টি পাথর অবশিষ্ট আছে।

    স্টেট-২ঃ এখন কোন প্লেয়ার চাল দিবে। 

২) সল্যুশনে আমরা প্রথম প্লেয়ার কে ০তম এবং ২য় প্লেয়ার কে ১তম প্লেয়ার হিসেবে বিবেচনা করেছি।

৩) বেস কেসে পৌঁছানো মানে এখন আর চাল দেয়া সম্ভব নয়। অর্থাৎ, বেস কেসে যদি ১ম প্লেয়ার পৌঁছায় তার মানে ২য় প্লেয়ার উইনার আর যদি ২য় প্লেয়ার পৌঁছায় তার মানে ১ম প্লেয়ার উইনার। 

৪) বেস কেস ভিন্ন, যেহেতু দুইজন প্লেয়ার অপ্টিমালি খেলবে সেহেতু এখন যদি ১ম প্লেয়ার এর চাল হয় তবে ১ম প্লেয়ার সম্ভাব্য সকল চাল এর মধ্যে যে চালে জিতবে সে চাল ই দিবে। একইভাবে ২য় প্লেয়ারও খেলবে। 

৫) যেহেতু, অ্যারে থেকে যেকোন সংখ্যাই নির্বাচন করা যায় সেহেতু একটি ইনার লুপ চালিয়ে অ্যারের সকল সংখ্যা নিয়েই চেষ্টা করতে হবে। 



Iterative Solution:

১) Iterative Solution এ dp[i][j] বলতে বুঝানো হয়েছে, স্তুপে পাথর সংখ্যা যদি i হয় এবং বর্তমান চাল যদি jth প্লেয়ার এর হয় তবে কোন প্লেয়ার জিতবে। 

রিকার্সিভ সল্যুশন বুঝে থাকলে বাকি অংশ বুঝতে সমস্যা হওয়ার কথা নয়। 



Next Episode

Happy Coding

Comments

Trending Post

Toph - Birthday Present Tutorial

All pair GCD Sum

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