Algorithms_in_C 1.0.0
Set of algorithms implemented in C.
Loading...
Searching...
No Matches
strong_number.c File Reference

Strong number is a number whose sum of all digits’ factorial is equal to the number n For example: 145 = 1!(1) + 4!(24) + 5!(120) More...

#include <assert.h>
#include <stdbool.h>
#include <stdio.h>
Include dependency graph for strong_number.c:

Functions

bool isStrong (int number)
 Check if given number is strong number or not.
 
void test ()
 Test function.
 
int main ()
 Driver Code.
 

Detailed Description

Strong number is a number whose sum of all digits’ factorial is equal to the number n For example: 145 = 1!(1) + 4!(24) + 5!(120)

Function Documentation

◆ isStrong()

bool isStrong ( int  number)

Check if given number is strong number or not.

Parameters
number
Returns
true if given number is strong number, otherwise false
16{
17 if (number < 0)
18 {
19 return false;
20 }
21 int sum = 0;
22 int originalNumber = number;
23 while (originalNumber != 0)
24 {
25 int remainder = originalNumber % 10;
26 int factorial = remainder == 0 ? 0 : 1; /* 0! == 1 */
27
28 /* calculate factorial of n */
29 for (int i = 1; i <= remainder; factorial *= i, i++)
30 {
31 ;
32 }
33 sum += factorial;
34 originalNumber /= 10;
35 }
36 return number == sum;
37}

◆ main()

int main ( void  )

Driver Code.

Returns
None
54{
55 test();
56 return 0;
57}
void test()
Test function.
Definition: strong_number.c:43
Here is the call graph for this function:

◆ test()

void test ( void  )

Test function.

Returns
void
44{
45 assert(isStrong(145)); /* 145 = 1! + 4! + 5! */
46 assert(!isStrong(543)); /* 543 != 5!+ 4! + 3! */
47}
bool isStrong(int number)
Check if given number is strong number or not.
Definition: strong_number.c:15
Here is the call graph for this function: