题目:
https://leetcode-cn.com/problems/binary-watch/
二进制手表顶部有 4 个 LED 代表 小时(0-11),底部的 6 个 LED 代表 分钟(0-59)。每个 LED 代表一个 0 或 1,最低位在右侧。
例如,下面的二进制手表读取 "3:25" 。
(图源:WikiMedia - Binary clock samui moon.jpg ,许可协议:Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0) )
给你一个整数 turnedOn ,表示当前亮着的 LED 的数量,返回二进制手表可以表示的所有可能时间。你可以 按任意顺序 返回答案。
小时不会以零开头:
例如,"01:00" 是无效的时间,正确的写法应该是 "1:00" 。
分钟必须由两位数组成,可能会以零开头:
例如,"10:2" 是无效的时间,正确的写法应该是 "10:02" 。
示例 1:
输入:turnedOn = 1
输出:["0:01","0:02","0:04","0:08","0:16","0:32","1:00","2:00","4:00","8:00"]
示例 2:
输入:turnedOn = 9
输出:[]
解释:
0 <= turnedOn <= 10
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-watch
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题关键思路:
现有2个数组
min_meta={8,4,2,1};
second_meta={32,16,8,4,2,1};
给出一个数,例如:N,需要返回数组里N个不重复的元素,例如
N=2;则min_answers=[[8,4],[8,2],[8,1],[4,2],[4,1],[2,1]];
N=3;则min_answers=[[8,2,1],[4,2,1]];
暂且抽象可能的数组组合为answer
注意:min_answer里的元素之和不能大于12,second_answer的元素之和不能大于60
分析可以发现
answer的length=N
answer[i],answer[i+1],answer[N]是一个递归求
代码实现
未完待续~~