大厂面试真题详解:分割字符串

简介: 大厂面试真题详解:分割字符串

给一个字符串,你可以选择在一个字符或两个相邻字符之后拆分字符串,使字符串由仅一个字符或两个字符组成,输出所有可能的结果
在线评测地址:领扣题库官网

样例1

输入: "123"
输出: [["1","2","3"],["12","3"],["1","23"]]

样例2

输入: "12345"
输出: [["1","23","45"],["12","3","45"],["12","34","5"],["1","2","3","45"],["1","2","34","5"],["1","23","4","5"],["12","3","4","5"],["1","2","3","4","5"]]

算法:DFS

由于本题可以选择在一个字符或两个相邻字符之后拆分字符串,且最后需输出所有可能的组合,即每次都需要把整个字符串按照特定要求切分完毕,可以想到利用递归dfs来完成;
算法步骤
对字符串进行深度优先搜索,当前位置达到字符串末尾作为边界。搜索时有两种情况:

  1. 切割当前的1个字符:
  • 将这1个字符单独作为字符串存入列表
  • 当前位置步进1
  1. 切割当前的连续2个字符(需满足当前位置不是字符串末尾):
  • 将连续2个字符保存为字符串存入列表
  • 当前位置步进2

复杂度分析

  • 时间复杂度:O(2^n), n为字符串长度

    • 除了字符串最后一位,其他位置都有两种切割方式
  • 空间复杂度:O(2^n^2),n为字符串长度

    • 存储所有情况需要所有切分方式*n 的空间
public class Solution {
    /*
     * @param : a string to be split
     * @return: all possible split string array
     */
    public List<List<String>> splitString(String s) {
        List<List<String>> result = new ArrayList<>();
        dfs(s, 0, new ArrayList<>(), result);
        return result;
    }

    private void dfs(String s, int index, List<String> current, List<List<String>> result) {
        if (index == s.length()) {
            result.add(new ArrayList<>(current));
            return;
        }
        // 分割1个字符
        current.add(String.valueOf(s.charAt(index)));
        dfs(s, index + 1, current, result);
        current.remove(current.size() - 1);
        // 分割2个字符
        if (index < s.length() - 1) {
            current.add(s.substring(index, index + 2));
            dfs(s, index + 2, current, result);
            current.remove(current.size() - 1);
        }
    }
}

更多题解参考:九章官网solution

相关文章
|
5天前
|
存储
力扣面试经典题之数组/字符串
力扣面试经典题之数组/字符串
27 0
|
5天前
面试题 08.08:有重复字符串的排列组合
面试题 08.08:有重复字符串的排列组合
28 0
|
5天前
面试题 02.04:分割链表
面试题 02.04:分割链表
38 0
|
3天前
|
索引 Python Go
【python学习】字符串详解,面试必问公司的问题
【python学习】字符串详解,面试必问公司的问题
|
5天前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
27 5
【刷题】 leetcode 面试题 01.06 字符串压缩
|
5天前
|
存储 Go 开发者
Golang深入浅出之-Go语言字符串操作:常见函数与面试示例
【4月更文挑战第20天】Go语言字符串是不可变的字节序列,采用UTF-8编码。本文介绍了字符串基础,如拼接(`+`或`fmt.Sprintf()`)、长度与索引、切片、查找与替换(`strings`包)以及转换与修剪。常见问题包括字符串不可变性、UTF-8编码处理、切片与容量以及查找与替换的边界条件。通过理解和实践这些函数及注意事项,能提升Go语言编程能力。
28 0
|
5天前
面试题 01.06. 字符串压缩
面试题 01.06. 字符串压缩
8 0
|
5天前
|
算法 测试技术 索引
力扣面试经典题之数组/字符串(二)
力扣面试经典题之数组/字符串(二)
15 0
|
5天前
|
存储 Java 编译器
Java字符串变量声明与赋值的常见面试题——完整剖析
Java字符串变量声明与赋值的常见面试题——完整剖析
23 1
LeetCode | 面试题 02.04. 分割链表
LeetCode | 面试题 02.04. 分割链表