【LeetCode每日一题】2788. 按分隔符拆分字符串

2024-1-20

文章目录

2788. 按分隔符拆分字符串
思路:
  1. 对于每个单词,使用一个可变字符串 StringBuilder 来构建拆分后的单词。初始时,可变字符串为空。
  2. 遍历每个单词的每个字符,如果遇到指定的分隔符,就将可变字符串中的字符构成一个新的单词,并将其添加到结果列表中。然后清空可变字符串,准备构建下一个单词。
  3. 如果遇到的不是分隔符,则将当前字符添加到可变字符串中。
  4. 最后,如果可变字符串非空,则说明最后一个单词还没有添加到结果列表中,因此需要将其添加到结果列表中。
  5. 返回拆分后的结果列表。
java 复制代码
//2788. 按分隔符拆分字符串
    public List<String> splitWordsBySeparator(List<String> words, char separator) {
        // 创建一个新的字符串列表,用于存储拆分后的结果
        List<String> res = new ArrayList<>();

        // 遍历原始字符串列表中的每个单词
        for (String word : words) {
            // 创建一个可变字符串,用于构建拆分后的单词
            StringBuilder sb = new StringBuilder();

            // 获取当前单词的长度
            int length = word.length();

            // 遍历当前单词的每个字符
            for (int i = 0; i < length; i++) {
                // 获取当前字符
                char c = word.charAt(i);

                // 如果当前字符是分隔符
                if (c == separator) {
                    // 如果可变字符串不为空,则将其添加到结果列表中,并清空可变字符串
                    if (sb.length() > 0) {
                        res.add(sb.toString());
                        sb.setLength(0);
                    }
                } else {
                    // 如果当前字符不是分隔符,则将其添加到可变字符串中
                    sb.append(c);
                }
            }

            // 如果可变字符串不为空,则将其添加到结果列表中
            if (sb.length() > 0) {
                res.add(sb.toString());
            }
        }

        // 返回拆分后的字符串列表
        return res;
    }

点击移步博客主页,欢迎光临~

相关推荐
2zcode13 分钟前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
小雅痞34 分钟前
[Java][Leetcode middle] 209. 长度最小的子数组
java·算法·leetcode
做时间的朋友。1 小时前
精准核酸检测
java·数据结构·算法
空中海1 小时前
iOS 动态分析、抓包与 Frida Hook
ios·职场和发展·蓝桥杯
冯诺依曼的锦鲤1 小时前
从零实现高并发内存池:TCMalloc 核心架构拆解
c++·学习·算法·架构
Thomas_Lee_OR1 小时前
多Agent路径规划 LaCAM for multi-agent path finding (MAPF)
算法·路径规划·仓储机器人·mapf
一切皆是因缘际会1 小时前
可落地数字生命工程:从记忆厮杀到自我意识觉醒全链路,AGI内生智能硅基生命心智建模
人工智能·深度学习·算法·机器学习·ai·系统架构·agi
nlpming1 小时前
opencode Agent 详解
算法
江南十四行1 小时前
排序算法进阶:直接插入排序(简单排序)与希尔排序
数据结构·算法·排序算法
nlpming1 小时前
opencode System Prompt 构建机制 & AGENTS.md注入机制
算法