C++ Exercises: Count the Amicable pairs in an array
C++ Numbers: Exercise-29 with Solution
Write a C++ program to count the amicable pairs in an array.
Sample Solution:
C++ Code :
#include <bits/stdc++.h> // Include all standard C++ libraries
using namespace std; // Using the standard namespace
int ProDivSum(int n)
{
int sum = 1; // Initializing sum with 1
for (int i = 2; i <= sqrt(n); i++) // Loop through numbers from 2 to square root of 'n'
{
if (n % i == 0) // Check if 'i' is a divisor of 'n'
{
sum += i; // Add 'i' to the sum
// To handle perfect squares, if 'n' is divisible by 'i' but not equal to 'i', add the corresponding divisor to the sum
if (n / i != i)
sum += n / i;
}
}
return sum; // Return the sum of proper divisors
}
bool chkAmicable(int a, int b)
{
return (ProDivSum(a) == b && ProDivSum(b) == a); // Return true if the sum of proper divisors of 'a' equals 'b' and vice versa
}
int ChkPairs(int arr[], int num1)
{
int ctr = 0; // Counter for amicable pairs
for (int i = 0; i < num1; i++) // Iterate through the array
{
for (int j = i + 1; j < num1; j++)
{
if (chkAmicable(arr[i], arr[j])) // Check if elements at index i and j form an amicable pair
ctr++; // Increment the counter if they are an amicable pair
}
}
return ctr; // Return the count of amicable pairs
}
int main()
{
int nn; // Declare variables
int n, i, j, ctr;
cout << "\n\n Count the Amicable pairs in a specific array: \n"; // Display a message
cout << " Sample pairs : (220, 284)(1184,1210) (2620,2924) (5020,5564) (6232,6368)... \n"; // Display sample pairs
cout << " ------------------------------------------------------------------------------\n";
cout << "\n Input the number of elements to be stored in the array: ";
cin >> nn; // Input the number of elements in the array
int arr1[nn]; // Declare an array of size nn
for (i = 0; i < nn; i++) // Input the elements of the array
{
cout << "element - " << i << ": ";
cin >> arr1[i];
}
int n1 = sizeof(arr1) / sizeof(arr1[0]); // Calculate the number of elements in the array
cout << " Number of Amicable pairs present in the array: " << ChkPairs(arr1, n1) << endl; // Count and display the number of amicable pairs in the array
return 0; // Exit the program
}
Sample Output:
Count the Amicable pairs in a specific array: Sample pairs : (220, 284)(1184,1210) (2620,2924) (5020,5564) (6232,6368)... ------------------------------------------------------------------------------ Input the number of elements to be stored in the array: 2 element - 0: 220 element - 1: 284 Number of Amicable pairs presents in the array: 1
Flowchart:
C++ Code Editor:
Contribute your code and comments through Disqus.
Previous: Write a program in C++ to check two numbers are Amicable numbers or not.
Next: Write a program in C++ to check if a given number is circular prime or not.
What is the difficulty level of this exercise?
It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.
https://w3resource.com/cpp-exercises/numbers/cpp-numbers-exercise-29.php
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics