使用kotlin解决这个题目:190. 颠倒二进制位 颠倒给定的 32 位无符号整数的二进制位。 提示: 请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整数类型,并且不应影响您的实现,因为无论整数是有符号的还是无符号的,其内部的二进制表示形式都是相同的。 在 Java 中,编译器使用二进制补码记法来表示有符号整数。因此,在 示例 2 中,输入表示有符号整数 -3,输出表示有符号整数 -1073741825。 示例 1: 输入:n = 00000010100101000001111010011100 输出:964176192 (00111001011110000010100101000000) 解释:输入的二进制串 00000010100101000001111010011100 表示无符号整数 43261596, 因此返回 964176192,其二进制表示形式为 00111001011110000010100101000000。 示例 2: 输入:n = 11111111111111111111111111111101 输出:3221225471 (10111111111111111111111111111111) 解释:输入的二进制串 11111111111111111111111111111101 表示无符号整数 4294967293, 因此返回 3221225471 其二进制表示形式为 10111111111111111111111111111111 。 提示: 输入是一个长度为 32 的二进制字符串
时间: 2024-02-13 09:00:16 浏览: 22
可以使用以下 Kotlin 代码来解决这个问题:
```kotlin
fun reverseBits(n: Int): Int {
var result = 0
for (i in 0 until 32) {
result = result shl 1 // 左移一位,为下一位腾出位置
if ((n shr i and 1) == 1) { // 获取原数字的第 i 位
result = result or 1 // 将第 i 位赋值给新数字的最低位
}
}
return result
}
```
该函数接受一个整数 n,表示一个无符号 32 位整数。函数通过循环将 n 的二进制位从低位到高位取出,并按照相反的顺序拼接成一个新的二进制数。具体来说,我们可以使用左移位运算符 `shl` 将新数字左移一位,为下一位腾出位置;再通过右移位运算符 `shr` 获取原数字的第 i 位,并将其赋值给新数字的最低位,即通过位运算符 `or` 将 1 赋值给最低位。
使用示例:
```kotlin
fun main() {
val n1 = 43261596
val n2 = 4294967293
println(reverseBits(n1)) // 输出 964176192
println(reverseBits(n2)) // 输出 3221225471
}
```
相关问题
使用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。
希望能对你有所帮助!
使用kotlin完成这个题目:400. 第 N 位数字 中等 375 相关企业 给你一个整数 n ,请你在无限的整数序列 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ...] 中找出并返回第 n 位上的数字。
以下是使用 Kotlin 实现的代码:
```kotlin
fun findNthDigit(n: Int): Int {
var base = 1
var digits = 1
var num = 9
while (n > num * digits) {
n -= num * digits
digits++
num *= 10
base *= 10
}
val index = (n - 1) / digits
val numStr = (base + index).toString()
val digitIndex = (n - 1) % digits
return numStr[digitIndex].toString().toInt()
}
```
该算法的思路如下:
1. 定义 `base`、`digits` 和 `num` 三个变量,分别表示当前位数的第一个数、当前位数的数字位数和当前位数的数字数目;
2. 如果 `n` 大于当前位数的数字总位数,则将 `n` 减去当前位数的数字总位数,增加 `digits`,`num` 乘以 10,`base` 也乘以 10;
3. 根据 `n` 计算当前位数上的数字在当前数字区间中的索引 `index`;
4. 将 `base` 和 `index` 相加得到当前位数上的数字的字符串表示;
5. 根据 `digitIndex` 取出该数字的对应位数上的字符,并将其转换为整数返回。
例如,当 `n` 为 15 时,根据算法计算可得当前位数为 2,`base` 为 10,`digits` 为 2,`num` 为 90。此时,我们需要找到第 15 个数字,减去 2 位数字所占的 18 个位数后,剩余 15 - 18 = -3,说明需要查找的数字在下一位,因此将 `digits` 增加 1,`num` 乘以 10,`base` 也乘以 10。此时,`digits` 为 3,`num` 为 900,`base` 为 100。继续计算可得当前位数上的数字在当前数字区间中的索引为 (15 - 18 - 3) / 3 = 1,因此当前位数上的数字为 100 + 1 = 101,第 15 个数字为 1。