题目:
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]是一个递归求

代码实现
未完待续~~
本文解析了LeetCode中的二进制手表问题,通过递归和组合数学探讨如何根据给定亮灯数量找出所有合法时间表示。关键在于理解LED组合限制并利用min_meta和second_meta数组进行求解。
900

被折叠的 条评论
为什么被折叠?



