List<String>变array
时间: 2023-07-09 19:16:04 浏览: 78
可以通过 List 对象的 toArray() 方法将其转换为数组。具体实现可以使用以下代码:
```
List<String> list = new ArrayList<>();
list.add("hello");
list.add("world");
String[] array = list.toArray(new String[0]);
```
其中,toArray() 方法可以传入一个指定类型的数组,如果数组长度小于 List 的长度,那么会创建一个新的数组,否则会使用传入的数组。这里我们传入了一个长度为 0 的 String 数组,表示创建一个新的数组。最终可以得到一个包含 List 中所有元素的 String 数组。
相关问题
class Solution { public List<List<String>> groupAnagrams(String[] strs) { Map<String, List<String>> map = new HashMap<String, List<String>>(); for (String str : strs) { char[] array = str.toCharArray(); Arrays.sort(array); String key = new String(array); List<String> list = map.getOrDefault(key, new ArrayList<String>()); list.add(str); map.put(key, list); } return new ArrayList<List<String>>(map.values());算法分析
这是 LeetCode 上的一个题目,要求将给定字符串数组按照由相同字符组成的顺序分组。该算法使用了哈希表来进行处理,具体分析如下:
1. 首先定义一个哈希表,键为字符串中字符按照字典序排序后的结果,值为由相同字符组成的字符串列表。
2. 遍历给定的字符串数组,对于每一个字符串,将其转化为字符数组,并对其进行排序。
3. 将排序后的字符数组转化为字符串,作为哈希表的键。
4. 从哈希表中获取键对应的值列表,如果没有则新建一个空列表。
5. 将当前字符串添加到值列表中。
6. 将更新后的值列表重新放回哈希表中。
7. 最后返回哈希表中所有值列表组成的列表,即为所求的结果。
该算法的时间复杂度为 O(NKlogK),其中 N 为字符串数组的长度,K 为字符串的平均长度,主要消耗在字符串排序上。空间复杂度为 O(NK),主要消耗在哈希表中存储的字符串列表上。
List<Object> list = Arrays.asList(array);转为List<String> list = Arrays.asList(array);
要将`List<Object> list`转换为`List<String> list`,可以使用以下代码:
```
List<Object> list = Arrays.asList(array);
List<String> stringList = list.stream()
.map(String::valueOf)
.collect(Collectors.toList());
```
这里,我们首先将`List<Object>`转换为流,并使用`map`方法将流中的每个元素转换为字符串类型。然后,使用`collect`方法将转换后的元素收集到新的`List<String>`中。最后,你可以使用`stringList`进行进一步的操作。
阅读全文