w3resource

JavaScript: Smallest number whose digits multiply to a number

JavaScript Math: Exercise-113 with Solution

Write a JavaScript program to calculate the smallest number whose digits multiply into a given number.

Example:
let n =100

Test Data:
(100) -> 455
(120) -> 358
(16) -> 28
(129) -> 0

Sample Solution:

JavaScript Code:

/**
 * Function to find the smallest number whose digits multiply to the given number.
 * @param {number} n - The given number.
 * @returns {number} - The smallest number whose digits multiply to the given number.
 */
function test(n) {
    if (n < 10) return n; // If n is less than 10, return n itself
    data = []; // Array to store all occurrences of digits
    for (i = 9; i > 1; i--) {
        // Store all occurrences of current digit in data 
        // if current digit divides n.
        while (n % i === 0) {
            n = n / i;
            data.push(i);
        }
    }

    if (n != 1) return 0; // If n is not 1, it means it contains a prime number greater than 9, so return 0
    result = 0; // Initialize result to store the smallest number whose digits multiply to n
    for (i = data.length - 1; i >= 0; i--) {
        result = result * 10 + data[i]; // Build the result number from the array data
        if (result > Number.MAX_VALUE) return 0; // If result exceeds the maximum value for a number, return 0
    }
    return result; // Return the smallest number whose digits multiply to n
}

// Test cases
n = 100;
console.log("n = " + n);
console.log("Smallest number whose digits multiply to the said number: " + test(n));
n = 120;
console.log("n = " + n);
console.log("Smallest number whose digits multiply to the said number: " + test(n));
n = 16;
console.log("n = " + n);
console.log("Smallest number whose digits multiply to the said number: " + test(n));
n = 129;
console.log("n = " + n);
console.log("Smallest number whose digits multiply to the said number: " + test(n));

Output:

n = 100
Smallest number whose digits multiply to the said number: 455
n = 120
Smallest number whose digits multiply to the said number: 358
n = 16
Smallest number whose digits multiply to the said number: 28
n = 129
Smallest number whose digits multiply to the said number: 0

Flowchart:

JavaScript: Smallest number whose digits multiply to a number.

Live Demo:

See the Pen javascript-math-exercise-113 by w3resource (@w3resource) on CodePen.


Improve this sample solution and post your code through Disqus.

Previous: Maximum value swapping two digits in an integer.
Next: Check a given number is self-dividing or not.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Follow us on Facebook and Twitter for latest update.