登录
首页 >  文章 >  java教程

Leetcode — 查找包含字符的单词

时间:2025-01-14 21:47:58 276浏览 收藏

你在学习文章相关的知识吗?本文《Leetcode — 查找包含字符的单词》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

Leetcode — 查找包含字符的单词

题目描述:给定一个字符串数组 words 和一个字符 x,返回包含字符 x 的所有单词的索引列表。

示例:

输入:words = ["leet","code"], x = "e" 输出:[0, 1]

输入:words = ["abc","bcd","aaaa","cbc"], x = "a" 输出:[0, 2]

输入:words = ["abc","bcd","aaaa","cbc"], x = "z" 输出:[]

解法一:迭代法

该方法直接迭代 words 数组,检查每个单词是否包含字符 x。如果包含,则将该单词的索引添加到结果列表中。

import java.util.List;
import java.util.ArrayList;
import java.util.stream.IntStream;
import java.util.stream.Collectors;

class Solution {
    public List findWordsContaining(String[] words, char x) {
        return IntStream.range(0, words.length)
                .filter(i -> words[i].indexOf(x) != -1)
                .boxed()
                .collect(Collectors.toList());
    }
}

两种方法都能有效解决问题。迭代法更易于理解,而流式处理方法更简洁,但对于大型数组,性能可能略有差异,需要根据实际情况选择。

性能比较:

迭代法通常在性能上略优于流式处理方法,尤其是在处理大型数组时。 但是,流式处理方法的代码更简洁易读。 实际性能差异取决于 JVM 的优化以及数组大小。

结论:

两种方法都能解决问题,选择哪种方法取决于个人偏好和性能要求。 对于大多数情况,迭代法是一个不错的选择,因为它简单易懂且性能通常更好。 如果追求代码简洁性,并且数组规模不是特别大,则流式处理方法也是一个很好的选择。

以上就是《Leetcode — 查找包含字符的单词》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>