DP Optimization(Part-4) | Longest Increasing Subsequence | DP Series(Episode-18)

 এই পর্বে আমরা মূলত ডাটা স্ট্রাকচার ব্যাবহারের মাধ্যমে কিছু কিছু ডিপি প্রব্লেমের কমপ্লেক্সিটি কিভাবে কমিয়ে আনা সম্ভব তা দেখবো। 

Problem:

মনে কর, তোমাকে একটি n<=10^4 সাইজের অ্যারে দেয়া আছে। এই অ্যারের দীর্ঘতম ক্রমবর্ধমান অনুক্রমের দৈর্ঘ্য বের করতে হবে😛

ইংরেজীতে বললে Longest Increasing Subsequence এর Length বের করতে হবে। তাহলে এই প্রব্লেমের সল্যুশন কি হতে পারে? 

Hints: শেষ থেকে শুরুর দিকে প্রত্যেক পজিশনে দাঁড়িয়ে দেখবো এই পজিশনের ভ্যালুটি অবশ্যই নিলে আমি সর্বোচ্চ কত লেন্থ এর LIS বানাতে পারবো। এভাবে সবগুলো রেজাল্ট এর মধ্যে ম্যাক্সিমাম টা এন্সার। 

কোডটি হলোঃ 



এখন, কী হবে যদি n<=10^5 এবং a[i]<=10^5 হয়? 
উপরের সল্যুশন এ ভালো করে লক্ষ্য করলে দেখবে যে, প্রত্যেক পজিশন i তে দাঁড়িয়ে আমরা দেখি i এর ডানে যেসব ভ্যালু আছে a[i] এর সমান অথবা বড় তাদের মধ্যে কার DP এর ভ্যালু সর্বোচ্চ? যেখানে, dp[i] বলতে বোঝায় ith to nth ইনডেক্সের ভ্যালুগুলো কনসিডার করে সর্বোচ্চ কত লেন্থ এর LIS বানানো যায়। 

একটু ভালো করে চিন্তা করলে দেখবে ১৫ নম্বর লাইনের ইনার লুপের কাজ আমরা সেগমেন্ট ট্রি এর একটি কুয়েরী আর আপডেট অপারেশন দ্বারা প্রতিস্থাপন করে দিতে পারি! যার ফলে আমাদের মোট কমপ্লেক্সিটি দাঁড়াবে n * log(n)

আমরা যখন কোন পজিশনের জন্য dp[i] বা LIS ক্যালকুলেট করবো তখন আমরা সেগমেন্ট ট্রি এর a[i] তম ইন্ডেক্সের ভ্যালু বানিয়ে দিবো dp[i] !!!  আর যেহেতু আমি শেষ থেকে শুরুর দিকে লুপ চালিয়ে ক্যালকুলেট করে যাচ্ছি সেহেতু এখন আমি i পজিশনে থাকা মানে i to nপর্যন্ত পজিশন গুলোর dp[i] ভ্যালুই সেগমেন্ট ট্রি তে আছে। 
তার মানে আমি যদি a[i] কে অবশ্যই নিয়ে সিকুয়েন্স বানাতে চাই সেক্ষেত্রে আমার জানতে হবে সেগমেন্ট ট্রি এর [ a[i] , 10^5 ] ইনডেক্স পর্যন্ত যেসব ভ্যালু আছে তাদের মধ্যে ম্যাক্সিমাম কত! 

এখনো না বুঝে থাকলে কোড দেখতে পারো। 

এখন চিন্তা কর যদি a[i] <= 10^9 হতো? 
সিম্পল! অ্যারে কম্প্রেশন করতাম সেক্ষেত্রে।

এখন, আমরা LIS বের করার আরো একটি কোড দেখবোঃ 
এই কোডের কমপ্লেক্সিটিও কিন্তু O(n log(n)) এবং এই কোড আগের কোডের তুলনায় অনেক ছোট!!! 

Suggested Problem here

Bonus Problem: Click here



Happy Coding😊

Comments

Trending Post

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

GCD of all numbers of given range of the array with point update

LeetCode - Single Number III