समस्या कथन
एक संख्या N को देखते हुए, हमें N को उनके योग के रूप में व्यक्त करने के लिए आवश्यक न्यूनतम पैलिंड्रोम की संख्या ज्ञात करनी होगी
यदि N =15 है तो 2 पैलिंड्रोम की आवश्यकता है अर्थात 8 और 7.
एल्गोरिदम
1. Generate all the palindromes up to N in a sorted fashion 2. Find the size of the smallest subset such that its sum is N
उदाहरण
#include <iostream> #include <vector> #include <climits> #include <algorithm> using namespace std; vector<vector<long long>> table; int createPalindrome(int input, bool isOdd){ int n = input; int palindrome = input; if (isOdd) n /= 10; while (n > 0) { palindrome = palindrome * 10 + (n % 10); n /= 10; } return palindrome; } vector<int>generatePalindromes(int n){ vector<int> palindromes; int number; for (int j = 0; j < 2; j++) { int i = 1; while ((number = createPalindrome(i++, j)) <= n) palindromes.push_back(number); } return palindromes; } long long minSubsetSize(vector<int>& vec, int i, int j, int n){ if (n == 0) return 0; if (i > j || vec[i] > n) return INT_MAX; if (table[i][n]) return table[i][n]; table[i][n] = min(1 + minSubsetSize(vec, i + 1, j, n - vec[i]), minSubsetSize(vec, i + 1, j, n)); return table[i][n]; } int requiredPalindromes(int n){ vector<int> palindromes = generatePalindromes(n); sort(palindromes.begin(), palindromes.end()); table = vector<vector<long long>>(palindromes.size(), vector<long long>(n + 1, 0)); return minSubsetSize(palindromes, 0, palindromes.size() - 1, n); } int main(){ int n = 15; cout << "Minimum required palindromes = " << requiredPalindromes(n) << endl; return 0; }
आउटपुट
जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं। यह निम्न आउटपुट उत्पन्न करता है -
Minimum required palindromes = 2