Coder Social home page Coder Social logo

401.二进制手表 about leetcode HOT 1 OPEN

zzcyes avatar zzcyes commented on July 28, 2024
401.二进制手表

from leetcode.

Comments (1)

zzcyes avatar zzcyes commented on July 28, 2024

题解

方法一:暴力法

/**
 * @param {number} num
 * @return {string[]}
 */
var readBinaryWatch = function(num) {
    if (num == 0) return ["0:00"];
    let result = [];
    for (let i = 0; i < 12; i++) {
        for (let j = 0; j < 60; j++) {
            if (calcNumLight(i) + calcNumLight(j) == num) {
                let str = `${i}:`;
                if (j < 10) {
                    str += `0${j}`;
                } else {
                    str += `${j}`;
                }
                result.push(str);
            }
        }
    }
    return result;
};

function calcNumLight(n) {
    let result = 0;
    while (n > 0) {
        result += n % 2;
        n = Math.floor(n / 2);
    }
    return result;
}

方法二:回溯

/**
 * @param {number} num
 * @return {string[]}
 */
var readBinaryWatch = function(num) {
    if (num === 0) {
        return ["0:00"];
    }
    const res = [];
    let h = num < 4 ? num : 3,
        m = num < 4 ? 0 : num - 3;
    while (0 <= h) {
        let hours = [];
        let mins = [];
        if (h < 4 && m < 6) {
            hours = getBinarys(h, 4, new Set());
            mins = getBinarys(m, 6, new Set());
        }
        for (const hh of hours) {
            for (const mm of mins) {
                res.push(`${hh}:${mm < 10 ? '0' + mm : mm}`);
            }
        }
        h--;
        m++;
    }
    return res;
};

function getBinarys(n, k, times) {
    if (n === 0) {
        return [0];
    }
    backtrack(new Array(k).fill(0), 0, n, times);
    return [...times.values()];
}

function backtrack(arr, m, n, times) {
    if (m === n) {
        const num = parseInt(arr.join(''), 2);
        const limit = arr.length < 6 ? 12 : 60;
        if (num < limit) {
            times.add(num);
        }
    }
    for (let i = 0; i < arr.length; i++) {
        if (arr[i]) continue;
        arr[i] = 1;
        backtrack(arr, m + 1, n, times);
        arr[i] = 0;
    }
}

from leetcode.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.