GCD of all numbers of given range of the array with range update
এই পর্ব পড়ার আগে Range GCD & Point Update পর্বটি পড়া আবশ্যক।
Problem: এই প্রব্লেমে আমাদের একটি অ্যারে দেয়া থাকবে n সাইজের এবং q সংখ্যক কুয়েরী এন্সার করতে হবে। দুই ধরনের কুয়েরী থাকবে।
1 L R অ্যারের L থেকে R Index পর্যন্ত সংখ্যাগুলোর GCD বের করতে হবে।
2 L R x অ্যারের L থেকে R ইনডেক্স পর্যন্ত সংখ্যাগুলোর ভ্যালু x বাড়াতে হবে।
Solution:
আমরা জানি,
GCD(a , b) = GCD(a , b-a) = GCD(a-b , b) = GCD(abs(a-b) , a) = GCD(abs(a-b) , b)
GCD(a , b , c) = GCD(a , GCD(b , c))
উপরোক্ত দুটি সমীকরণ থেকে লিখতে পারি,
GCD(a , b , c) = GCD(a , GCD(b-a , c-b))
অর্থাৎ, GCD(a[l] , a[l+1] , a[l+2] , ... , a[r]) = GCD(a[l] , a[l+1]-a[l] , a[l+2]-a[l+1] , ... , a[r]-a[r-1])
এখন, এই প্রব্লেম এ আমরা দুটি সেগমেন্ট ট্রি ব্যাবহার করবো।
১) ১ম সেগমেন্ট ট্রি তে আমরা মূল অ্যারের বর্তমান অবস্থা কি সেটার হিসাব রাখবো। অর্থাৎ, মূল অ্যারের কোন ইনডেক্সের ভ্যালু বর্তমানে কত সেটা জানবো। এবং রেঞ্জ আপডেট করবো।
২) এরপর, আমরা মূল অ্যারের জন্য একটি ডিফারেন্স অ্যারে তৈরী করবো। যেখানে,
dif[i] = ara[i] - ara[i-1]
৩) ২য় সেগমেন্ট ট্রি মূলত ডিফারেন্স অ্যারের একটি সাবঅ্যারের GCD বের করে দিতে সাহায্য করবে আমাদের।
এখন, একটি বিষয় লক্ষ্য করা যাক তা হলো মনে করি l to r ইনডেক্সের ভ্যালু x বাড়াতে হবে। তাহলে ডিফারেন্স অ্যারে তে কি পরিবর্তন আসবে?
dif[l] += x
dif[r+1] -= x
মানে ডিফারেন্স অ্যারে তে শুধু দুটি পয়েন্ট আপডেট করতে হবে। l তম ইনডেক্সের ভ্যালু x বাড়বে আর r+1 তম ইনডেক্সের ভ্যালু x কমবে।
আশা করি, এখন প্রব্লেমটি সলভ করা সম্ভব। নিজে নিজে কোড করার চেষ্টা করেও ব্যার্থ হলে নিচে কোড দেখে নিতে পারো।
Click here to solve similar problem
Happy Coding
Comments
Post a Comment