kotlin 输入字符串数组
时间: 2023-12-22 22:50:26 浏览: 29
可以使用以下代码来输入字符串数组:
```kotlin
val inputArray = readLine()!!.split(" ").toTypedArray()
```
其中,readLine()函数从标准输入读取一行字符串,split(" ")将字符串按空格分割成字符串列表,toTypedArray()将字符串列表转化为字符串数组。
相关问题
使用kotlin完成这个题目:14. 最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 ""。 示例 1: 输入:strs = ["flower","flow","flight"] 输出:"fl" 示例 2: 输入:strs = ["dog","racecar","car"] 输出:"" 解释:输入不存在公共前缀。 提示: 1 <= strs.length <= 200 0 <= strs[i].length <= 200 strs[i] 仅由小写英文字母组成 通过次数1,090,936提交次数2,518,195
可以使用 Kotlin 的字符串操作来完成这个题目,具体实现如下:
```kotlin
fun longestCommonPrefix(strs: Array<String>): String {
if (strs.isEmpty()) return ""
val first = strs[0]
for (i in first.indices) {
val char = first[i]
for (j in 1 until strs.size) {
val str = strs[j]
if (i >= str.length || str[i] != char) {
return first.substring(0, i)
}
}
}
return first
}
```
首先判断字符串数组是否为空,如果为空,则直接返回空字符串。然后以第一个字符串为基准,遍历其所有字符,依次与其他字符串的同一位置的字符进行比较,如果不一致或者到达其他字符串的末尾,则说明公共前缀已经结束,返回当前字符串的前缀即可。如果遍历完第一个字符串,没有发现不一致的字符,则说明第一个字符串本身就是公共前缀,直接返回即可。
使用kotlin解决这个问题:344. 反转字符串 编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。 示例 1: 输入:s = ["h","e","l","l","o"] 输出:["o","l","l","e","h"] 示例 2: 输入:s = ["H","a","n","n","a","h"] 输出:["h","a","n","n","a","H"] 提示: 1 <= s.length <= 105 s[i] 都是 ASCII 码表中的可打印字符
以下是使用 Kotlin 解决 LeetCode 344. 反转字符串问题的代码:
```kotlin
fun reverseString(s: CharArray) {
var left = 0
var right = s.size - 1
while (left < right) {
val temp = s[left]
s[left] = s[right]
s[right] = temp
left++
right--
}
}
```
解题思路:
我们可以使用双指针的方法来解决此问题。我们定义两个指针 left 和 right,分别指向数组的首尾位置,每次交换 left 和 right 指向的字符,然后将 left 指针右移一位,right 指针左移一位,直到 left >= right 为止。
时间复杂度:O(n),其中 n 是输入字符数组的长度。
空间复杂度:O(1)。
注意:本题也可以使用递归的方法来解决,但是递归的空间复杂度是 O(n),不符合题目要求,此处不再赘述。