C++ program to check if a number is spy number or not:
In this C++ program, we will learn how to check if a number is a spy number or not. A number is called a spy number if the sum of the digits of the number is equal to the product of the digits. The program will take a number as an input from the user and check if the number is a spy number or not.
For example, 132 is a spy number. Because the sum of the digits of this number is 1 + 3 + 2 = 6 and the product of the digits of this number is 1 * 3 * 2 = 6. Both are equal.
Algorithm:
We will use the below algorithm:
- Take the number as input from the user and save it to a variable.
- Initialize one variable as 0 to hold the sum of digits of the number. Initialize one more variable as 1 to hold the product of digits of the number.
- Run one loop till the number is greater than 0.
- On each iteration, get the last digit of the number by using modulo. Add this digit to the sum variable and multiply it to the product variable.
- Remove the last digit of the number by dividing it by 10.
- Once the loop ends, compare the sum variable with the product variable. If both are equal, this is a spy number. Else, it is not.
Example 1: C++ program to check if a number is spy number or not:
The below program checks if a number is spy number or not:
#include <iostream>
using namespace std;
int main()
{
int num, sum = 0, product = 1, lastDigit;
cout << "Enter a number: " << endl;
cin >> num;
while (num > 0)
{
lastDigit = num % 10;
sum += lastDigit;
product *= lastDigit;
num /= 10;
}
if (sum == product)
{
cout << "It is a spy number !!" << endl;
}
else
{
cout << "It is not a spy number !!" << endl;
}
}
Here,
- Four integer variables are created in the beginning of the program. The variable num is used to store the number, sum is used to store the sum of digits of the number, product is used to store the product of the digits of the number, and lastDigit is used to store the last digit of the number.
- It asks the user to enter the number. This is assigned to the num varable.
- The while loop finds the sum and products of the digits of the number.
- On each iteration, it finds the last digit of the number and adds it to the sum variable. Also, it multiplies it to the product variable.
- At the end of each iteration, it removes the last digit of the number.
- Once the while loop ends, it compares the values of sum and product and prints one message.
If you run this program, it will print output as like below:
Enter a number:
132
It is a spy number !!
Enter a number:
133
It is not a spy number !!
Example 2: C++ program to check if a number is spy number or not by using a separate function:
Let’s use a separate function to find out if a number is spy number or not. This function will take one number as the parameter and return one boolean value.
#include <iostream>
using namespace std;
bool isSpy(int num)
{
int sum = 0, product = 1, lastDigit;
while (num > 0)
{
lastDigit = num % 10;
sum += lastDigit;
product *= lastDigit;
num /= 10;
}
return sum == product;
}
int main()
{
int num;
cout << "Enter a number: " << endl;
cin >> num;
if (isSpy(num))
{
cout << "It is a spy number !!" << endl;
}
else
{
cout << "It is not a spy number !!" << endl;
}
}
- isSpy is a separate function to check if a number is spy or not. It takes one number as the parameter and returns one boolean value: *true if the number is spy and false otherwise.
- isSpy is using the same process similar to the previous example to check if the provided number is spy or not.
- It returns one boolean value and based on it, the if-else block in the main method prints a message.
It will print similar output.
Enter a number:
133
It is not a spy number !!
Enter a number:
1412
It is a spy number !!
You might also like:
- C++ STL accumulate method explanation with example
- C++ program to convert hexadecimal to decimal
- C++ program to find the sum of the first and last digits of a number
- C++ program to find all prime numbers to n using sieve of Eratosthenes algorithm
- C++ program to print all subsets of a set
- How to sort an array in ascending order in C++
- C++ program to solve a quadratic equation in different ways
- 3 ways to find the exponent without using pow() method in C++
- 3 different C++ programs to find electricity bill with user given units