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
Post a Comment