ধারণা
প্রদত্ত দুটি সংখ্যা P এবং Q ( P এবং Q 10^6 পর্যন্ত হতে পারে) যা একটি সংখ্যাN =(P!/Q!) গঠন করে। আমাদের কাজ হল সম্ভাব্য সর্বাধিক সংখ্যক অপারেশন সম্পাদন করে N 1 থেকে কমানো। মনে রাখবেন, প্রতিটি অপারেশনে, একজন N কে N/X দিয়ে প্রতিস্থাপন করতে পারে যদি N X দ্বারা বিভাজ্য হয়। সম্ভব হতে পারে এমন সর্বাধিক সংখ্যক অপারেশন নির্ধারণ করুন।
ইনপুট
A = 7, B = 4
আউটপুট
4
ব্যাখ্যা
N হল 210 এবং ভাজক হল 2, 3, 5, 7
ইনপুট
A = 3, B = 1
আউটপুট
2
ব্যাখ্যা
N হল 6 এবং ভাজক হল 2,3৷
পদ্ধতি
এটা লক্ষ্য করা গেছে যে P!/Q সংখ্যার ফ্যাক্টরাইজেশন! এটা কি সংখ্যার ফ্যাক্টরাইজেশন (Q + 1)*(Q + 2)*…*(P – 1)*P।
এটাও লক্ষ করা উচিত, যদি আমরা শুধুমাত্র এর মৌলিক গুণনীয়কগুলির সাথে N দিয়ে ভাগ করি তাহলে ক্রিয়াকলাপের সংখ্যা সর্বাধিক হবে। এর ফলস্বরূপ, অন্য কথায় আমাদের N এর মৌলিক গুণনীয়কগুলির গণনা নির্ধারণ করতে হবে যার মধ্যে ডুপ্লিকেটগুলিও রয়েছে৷
2 থেকে 1000000 পর্যন্ত প্রতিটি সংখ্যার গুণিতককরণে মৌলিক গুণনীয়কের সংখ্যা গণনা করুন।
প্রথমে, Sieve of Eratosthenes প্রয়োগ করুন এই সংখ্যাগুলির প্রতিটির একটি মৌলিক ভাজক নির্ধারণ করার জন্য। এটি নিম্নরূপ ব্যাখ্যা করা হয়েছে −
-
2 থেকে N পর্যন্ত ধারাবাহিক পূর্ণসংখ্যার একটি তালিকা তৈরি করুন:(2, 3, 4, …, N)।
-
প্রথমে, অনুমান করুন p সমান 2, প্রথম মৌলিক সংখ্যা।
-
p^2 থেকে শুরু করে, p এর বৃদ্ধিতে গণনা করুন এবং তালিকায় p^2 এর থেকে বড় বা সমান এই সংখ্যাগুলির প্রতিটি নির্দেশ করুন। সুতরাং, এই সংখ্যাগুলি p(p+1), p(p+2), p(p+3), ইত্যাদি হতে পারে।
-
তালিকায় p এর চেয়ে বড় প্রথম সংখ্যাটি নির্ধারণ করুন যা নির্দেশিত নয়। এটা দেখা গেছে যে এই ধরনের কোন সংখ্যা না থাকলে, বন্ধ করুন। অন্যথায়, অনুমান করুন p এখন এই সংখ্যার সমান (যা পরবর্তী প্রাইম নির্দেশ করে), এবং আবার ধাপ 3 থেকে পুনরাবৃত্তি করুন।
Eratosthenes পদ্ধতির চালনি প্রয়োগ করার পর আমরা নিম্নলিখিত সূত্রটি বাস্তবায়নকারী একটি ফ্যাক্টরাইজেশনের মূল ফ্যাক্টরগুলির সংখ্যা গণনা করতে পারি -
primefactors[num] =primefactors[num / primedivisor[num]] + 1বর্তমানে, কেউ প্রাইম ফ্যাক্টরের জন্য উপসর্গ যোগ অ্যারে প্রয়োগ করতে পারে এবং তারপর ওনান ব্যবধান [P, Q] যোগফলের জন্য উত্তর দিতে পারে।
উদাহরণ
// CPP program to find maximum // number moves possible #include <bits/stdc++.h> using namespace std; #define N 1000005 // Used to store number of prime // factors of each number int primeFactors1[N]; // Shows Function to find number of prime // factors of each number void findPrimeFactors(){ for (int a = 2; a < N; a++) // Now if a is a prime number if (primeFactors1[a] == 0) for (int b = a; b < N; b += a) // Now increase value by one from // it's preveious multiple primeFactors1[b] = primeFactors1[b / a] + 1; // Build prefix sum // this will be helpful for // multiple test cases for (int a = 1; a < N; a++) primeFactors1[a] += primeFactors1[a - 1]; } // Driver Code int main(){ // Create primeFactors1 array findPrimeFactors(); int P = 7, Q = 4; // required answer cout << primeFactors1[P] - primeFactors1[Q]; return 0; }
আউটপুট
4