使用kotlin完成这个题目:401. 二进制手表 二进制手表顶部有 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
时间: 2023-07-05 12:16:08 浏览: 51
以下是使用 Kotlin 实现的代码:
```kotlin
class Solution {
fun readBinaryWatch(turnedOn: Int): List<String> {
val res = mutableListOf<String>()
for (hour in 0..11) {
for (minute in 0..59) {
if (Integer.bitCount(hour) + Integer.bitCount(minute) == turnedOn) {
res.add("$hour:${minute.toString().padStart(2, '0')}")
}
}
}
return res
}
}
```
该算法很简单,它遍历了小时和分钟的所有可能值,并计算亮灯的数量。如果亮灯的数量等于输入的 `turnedOn` 参数,则将当前时间添加到结果列表中。
在这个算法中,我们使用了 `Integer.bitCount()` 函数来计算一个整数中的二进制位数。`toString().padStart(2, '0')` 函数用于将分钟数转换为两位数字。
相关问题
使用kotlin完成这个题目:67. 二进制求和 给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 示例 1: 输入:a = "11", b = "1" 输出:"100" 示例 2: 输入:a = "1010", b = "1011" 输出:"10101" 提示: 1 <= a.length, b.length <= 104 a 和 b 仅由字符 '0' 或 '1' 组成 字符串如果不是 "0" ,就不含前导零 通过次数324,156提交次数611,721 请问您在哪类招聘中遇到此题?
以下是使用 Kotlin 编写的解法:
```kotlin
fun addBinary(a: String, b: String): String {
val result = StringBuilder()
var carry = 0
var i = a.length - 1
var j = b.length - 1
while (i >= 0 || j >= 0 || carry > 0) {
val sum = (if (i >= 0) a[i--] - '0' else 0) +
(if (j >= 0) b[j--] - '0' else 0) +
carry
result.append(sum % 2)
carry = sum / 2
}
return result.reverse().toString()
}
```
该函数接收两个二进制字符串 `a` 和 `b`,并返回它们的和。
具体实现是通过循环遍历两个字符串,从末位开始逐位相加,并记录进位。需要注意的是,如果其中一个字符串已经遍历完了,需要在计算时将其对应的位视作 0。最后将结果翻转后返回即可。
在本题中,我们可以使用 `StringBuilder` 来动态添加结果,避免多次字符串拼接带来的性能问题。
使用kotlin完成这个题目:459. 重复的子字符串 给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。
这道题可以使用字符串匹配的方法来解决。
具体来说,我们可以将原始字符串 s 拼接自身,然后去掉开头和结尾两个字符,这样得到的字符串一定包含原始字符串 s。
接下来,我们可以使用 KMP 算法或者 Z 算法来求出该字符串的前缀函数或者 Z 函数,然后判断原始字符串 s 的长度是否等于这个函数的最后一个值,如果是,说明原始字符串 s 可以由一个子串重复多次构成。
具体实现可以参考以下代码:
```kotlin
fun repeatedSubstringPattern(s: String): Boolean {
val n = s.length
val str = s + s
val pi = IntArray(n * 2)
var j = 0
for (i in 1 until n * 2) {
while (j > 0 && str[i] != str[j]) {
j = pi[j - 1]
}
if (str[i] == str[j]) {
j++
}
pi[i] = j
}
return pi[n * 2 - 1] != 0 && n % (n - pi[n * 2 - 1]) == 0
}
```
其中,`pi` 数组表示字符串 `str` 的前缀函数,`j` 表示匹配的长度,初始值为 `0`。
在循环中,我们不断地向右移动指针 `i`,并且不断地将 `j` 更新为 `pi[j-1]`,直到 `str[i]` 和 `str[j]` 相等,或者 `j` 为 `0`。如果 `str[i]` 和 `str[j]` 相等,我们就将 `j` 增加 1,并且将 `pi[i]` 赋值为 `j`。
最后,我们判断 `pi[n*2-1]` 是否为 0,并且判断 `n` 是否能被 `n-pi[n*2-1]` 整除。如果是,说明原始字符串 s 可以由一个子串重复多次构成,返回 true,否则返回 false。
希望能对你有所帮助!