zoukankan      html  css  js  c++  java
  • [LeetCode]习题记录

    #include <iostream>
    #include <fstream>
    #include <cstdlib>
    #include <string>
    #include <cctype>
    #include <array>
    #include <iomanip>
    
    using namespace std;
    string count(int n);
    int main() {
        int n;
        string countout;
        cin >> n;
        countout=count(n);
        cout << """ << countout << """;
        return 0;
    }
    string count(int n) {
        string out;
        if (n == 1) {
            return "1";
        }
        else if (n == 2) {
            return "11";
        }
        else {
            string a = count(n - 1);
            int i = 1, j = 1;
            int num = a.size();
            while (i<num)
            {
                if (a[i] == a[i - 1]) {
                    j++;
                    if(i==(num-1))
                        out =out + to_string(j) + a[i];
                }
                else
                {
                    out =out + to_string(j) + a[i-1];
                    j = 1;
                    if (i == (num - 1))
                        out =out + to_string(j) + a[i];
                }
                i++;
            }
        }
        return out;
    }

     401. Binary Watch

    A binary watch has 4 LEDs on the top which represent the hours (0-11), and the 6 LEDs on the bottom represent the minutes (0-59).

    Each LED represents a zero or one, with the least significant bit on the right

     

     For example, the above binary watch reads "3:25".

    Given a non-negative integer n which represents the number of LEDs that are currently on, return all possible times the watch could represent.

     解决方法

    //法1:找到规律,用技巧解
    class Solution {
    public:
        vector<string> readBinaryWatch(int num) {
            vector<string> rs;
            for (int h = 0; h < 12; ++h) {
                for (int m = 0; m < 60; ++m) {
                    if (bitset<10>(h << 6 | m).count() == num)
                        rs.emplace_back(to_string(h) + ((m < 10) ? ":0" : ":") + to_string(m));
                }
            }
            return rs;
        }
    };
    //法2:回溯法,逐个深入解决
    class Solution 
    {
        // date: 2016-09-18     location: Vista Del Lago III
        vector<int> hour = {1, 2, 4, 8}, minute = {1, 2, 4, 8, 16, 32};
    public:
        vector<string> readBinaryWatch(int num) {
            vector<string> res;
            helper(res, make_pair(0, 0), num, 0);
            return res;
        }
        
        void helper(vector<string>& res, pair<int, int> time, int num, int start_point) {
            if (num == 0) {
                res.push_back(to_string(time.first) +  (time.second < 10 ?  ":0" : ":") + to_string(time.second));
                return;
            }
            for (int i = start_point; i < hour.size() + minute.size(); i ++)
                if (i < hour.size()) {    
                    time.first += hour[i];
                    if (time.first < 12)     helper(res, time, num - 1, i + 1);     // "hour" should be less than 12.
                    time.first -= hour[i];
                } else {     
                    time.second += minute[i - hour.size()];
                    if (time.second < 60)    helper(res, time, num - 1, i + 1);     // "minute" should be less than 60.
                    time.second -= minute[i - hour.size()];
                }
        }
    };

     法1将每一时刻穷举出来,使用bitset进行位运算,将h左移六位与m拼接起来,并计算其中1的位数与给定数字比较,若相等则存入。

    法2使用回溯法,按照DFS(深度优先搜索)规则进行带剪枝的穷举。

  • 相关阅读:
    Redis过期key是怎么样清理的?----互联网大厂面试题
    Docker容器引擎使用教程
    区块链算法
    MYSQL 常用语句与函数命令
    漏洞利用:验证绕过,XSS利用,Cookic盗用,文件上传
    小白网工入行要具备哪些基本技能?
    VMware中乌班图安装VMtools步骤
    防火墙技术原理-思维导图
    JAVA学习第一课-手工笔记
    DOS(磁盘操作系统)基本命令-思维导图
  • 原文地址:https://www.cnblogs.com/lightmonster/p/10315172.html
Copyright © 2011-2022 走看看