codebuddies/DailyAlgorithms

[Leetcode] Rotated Digits

Opened this issue · 1 comments

X is a good number if after rotating each digit individually by 180 degrees, we get a valid number that is different from X. Each digit must be rotated - we cannot choose to leave it alone.

A number is valid if each digit remains a digit after rotation. 0, 1, and 8 rotate to themselves; 2 and 5 rotate to each other; 6 and 9 rotate to each other, and the rest of the numbers do not rotate to any other number and become invalid.

Now given a positive number N, how many numbers X from 1 to N are good?

Example:
Input: 10
Output: 4
Explanation:
There are four good numbers in the range [1, 10] : 2, 5, 6, 9.
Note that 1 and 10 are not good numbers, since they remain unchanged after rotating.

var rotatedDigits = function(N) {
    let counter = 0;
    for (let i=1; i <= N; i++) {
        let strNumber = i.toString();
        //console.log("strNumber", strNumber)
        let rotation = "";
        let digit;
        for (let num = 0; num < strNumber.length; num++) {
            digit = strNumber[num];
            if (digit === "3" || digit === "4" || digit === "7") {
                num += strNumber.length;
                rotation = strNumber;
            } else if (digit === "2") {
                rotation += "5"
            } else if (digit === "5") {
                rotation += "2"
            } else if (digit === "6") {
                rotation += "9"
            } else if (digit === "9") {
                rotation += "6"
            } else {
                rotation += digit;
            }
         }
        
//         console.log('strNumber is: ', strNumber)
//         console.log('rotation is: ', rotation)
        if (rotation !== strNumber) {
            counter++;
        }
    }
    return counter;
};