Light OJ - 1193 Tutorial | DP Series(Episode-21)

 Problem Description here


Problem:

এই প্রব্লেমে আমাদেরকে n সংখ্যক ডাইস দেয়া থাকবে। প্রতিটি ডাইসের k সংখ্যক তল থাকে যাদেরকে 1,2,3,....,k দ্বারা সংখ্যায়িত করা হয়। আমি ডাইসগুলো যেকোনভাবে সাজাতে পারি। সাজানোর পর যদি সকল ডাইসের উপরের তলের সংখ্যাগুলোর যোগফল S এর সমান হয় তবে স্কোর হবে উপরের তলের সংখ্যাগুলোর গুণফলের সমান। 

এখন, আমাকে যতোগুলো ভ্যালিড ওয়ে তে সাজানো যায় সবগুলোর জন্য স্কোর এর যোগফল হিসেব করতে হবে।

 

এই প্রব্লেমটি আমার সলভ করা ডিপি অপটিমাইজেশনের অন্যতম মজার একটি প্রব্লেম। এই প্রব্লেম সলভ করার আগে আমি ডিপি অপটিমাইজেশন নিয়ে যে পর্বগুলো লিখেছি সবগুলো পড়ে আসতে হবে। এবং DICE-1 প্রব্লেমটি সলভ করে আসতে হবে। 

DP Optimization-1

DP Optimization-2

DP Optimization-3

DP Optimization-4

Light OJ 1145


Solution:

১) Prerequisite গুলো পূরণ করে আসলে দুইটা প্রব্লেম ই সিমিলার মনে হবে শুরুতেই। DICE(I) এর সল্যুশনে প্রথম যে ফাংশনটি লিখেছিলাম আমি ঠিক সেরকম একটি ফাংশন লিখতে পারবা এই প্রব্লেমের জন্য যাতে ছোট Constraint এর জন্য কাজ করে? 

আগের প্রব্লেমের সল্যুশনে ২৯ নাম্বার লাইনটি কি ছিলো?

dp[i][j]  +=  dp[i][j-val]

এখন, এই লাইনটি পরিবর্তিত হয়ে হবেঃ

dp[i][j] += (val * dp[i+1][j-val]


২) এখন, আমরা ধীরে ধীরে অপটিমাইজেশনে যাবো। এখানেও আগের প্রব্লেমের মতো করেই থার্ড ইনার লুপ টা গায়েব করে দিতে হবে!!! আগের প্রব্লেমে আমরা শুধুমাত্র প্রিপিক্স সাম ব্যাবহার করে এই কাজটি করতে সফল হয়েছিলাম। এখানেও কি হবো?


৩) খুবভালোভাবে লক্ষ্য করলে দেখবে যে, এই থার্ড ইনার লুপ রিপ্লেস করতে গিয়ে আমাদের ছোটখাটো আরেকটি প্রব্লেম সলভ করতে হবে। কেমন? 

প্রব্লেমটা হচ্ছে মোটামুটি এরকম যে আমাকে একটি অ্যারে ara[n] দেয়া থাকবে। আমি এই অ্যারের x সাইজের একটি সাবঅ্যারের উপর কাজ করবো। আমাকে ঐ সাবঅ্যারের rightmost এলিমেন্ট কে 1 দ্বারা, 2nd rightmost এলিমেন্ট কে 2 দ্বারা, 3rd rightmost এলিমেন্ট কে 3 দ্বারা এভাবে xth rightmost এলিমেন্ট কে x দ্বারা গুণ করে সবগুলো গুণফলের যোগফল বের করতে হবে। 


এখন, আমাদের মূল চ্যালেঞ্জই হচ্ছে এই কাজটি O(1) কমপ্লেক্সিটি তে করা। তাহলেই আমরা এই প্রব্লেম সলভ করতে পারবো।


এখন, আমাকে একটি অ্যারে ara[n] দিয়ে দেয়া হবে। 

মনে কর, আমার কাছে দুইটি অ্যারে p[n] এবং q[n] আছে। এরা সকলেই 1-indexed অ্যারে। 

p[i] = p[i-1] + ara[i]

q[i] = q[i-1] + p[i]

এখন, আমরা ara[lb....ub] এই সাব-অ্যারের জন্য উপরোক্ত প্রব্লেমটি কিভাবে সলভ করতে পারি? 

এই সাব-অ্যারের জন্য এন্সার হবেঃ q[ub] - q[lb-1] - (sizeofsubarray * p[lb-1])


নিশ্চয়ই মাথার উপর দিয়ে গেছে! যাওয়া টা স্বাভাবিক। এই সাবপ্রব্লেমের সল্যুশন যেহেতু নিজে নিজে বের করোনি, অন্তত এই সল্যুশন কেন এবং কীভাবে কাজ করে সেটি নিজে নিজে বের করো।


যেহেতু তুমি DICE(I) প্রব্লেম সলভ করে এসেছো আমার কথামতো এবং এই প্রব্লেমের মূল চ্যালেঞ্জটিও অতিক্রম করে ফেলেছো, এখন তোমার উচিৎ সল্যুশন টি নিজে নিজে লিখা।


এরপরও ব্যার্থ হলে সল্যুশন দেখে নিতে পারো।

Happy Coding 😊

Comments

Trending Post

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

Magic In Grid

At Coder Educational DP-B | DP Series(Episode-2)