Light OJ - 1269 - Consecutive Sum Tutorial

Problem Description here

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

সলুশ্যন আইডিয়াঃ

সাবঅ্যারের XOR কথাটি আসলেই মূলত PrefixXOR এর আইডিয়া আসে। 

১) অ্যারেটির PrefixXOR বের করে রাখবো। এখন, অ্যারের l to r ইনডেক্সের XOR মানে কী? 
PrefixXOR[r] ^ PrefixXOR[l-1]

২) ক্রমানুসারে প্রতিটি PrefixXOR এর বিট গুলো নিবো MSB থেকে LSB।
আমি যদি এখন PrefixXOR অ্যারের ith পজিশনে থাকি তাহলে ট্রাই তে 0 to (i-1) পজিশন পর্যন্ত PrefixXOR অ্যারের প্রতিটা এলিমেন্ট এর বিট সিকুয়েন্স স্টোর করা আছে। 

এখন, বর্তমান এলিমেন্ট এর জন্য এর পূর্বের অল পসিবল সাবঅ্যারের XOR এর কাজটা আমরা ট্রাই তে স্টোরড ডেটা থেকে করতে পারি। কীভাবে?

বর্তমান বিট সিকুয়েন্স এর একটা পজিশনে যদি ০ থাকে আমি চেষ্টা করবো ট্রাই এর বর্তমান নোড থেকে ১ এর পথে যেতে। বিট সিকুয়েন্সে যদি ১ থাকে আমি চেষ্টা করবো ট্রাই এর বর্তমান নোড থেকে ০ এর পথে যেতে। Desired পথ না থাকলে অন্য পথে যাবো। আর যেতে পারলে এই বিটের জন্য উপযুক্ত ভ্যালু একটা ভ্যারিয়েবলে যোগ করবো এবং সবশেষে তা রিটার্ন করবো। এভাবে, আমরা 1 থেকে বর্তমান ইনডেক্স পর্যন্ত অল-পসিবল সাবঅ্যারের জন্য ম্যাক্সিমাম ভ্যালু পাবো। 

মিনিমাম বের করার জন্য ঠিক তার উল্টোটা হবে। 

খাতা কলমে কিছুটা চিন্তা করলে আশা করি লজিকটি বুজতে সহজ হবে। এরপরেও না হলে সলুশ্যন দেখতে পারো নিজ দায়িত্বে।

বিঃদ্রঃ সলুশ্যন দেখে প্রব্লেম সলভ করা ভালো প্র্যাকটিস না।


Comments

Trending Post

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

Light OJ - 1011- Marriage Ceremonies - Tutorial

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