博客
关于我
largeGroupPositions-较大分组的位置
阅读量:659 次
发布时间:2019-03-15

本文共 1437 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要找出字符串中所有较大分组的区间。较大分组是指由连续的三个或更多相同字符组成的分组。我们将这些区间按起始位置下标递增顺序排序后返回结果。

方法思路

  • 初始化变量:我们用 startend 来记录当前分组的起始和结束位置。
  • 遍历字符串:从字符串的第二个字符开始遍历。如果当前字符和前一个字符相同,则继续当前分组,否则检查当前分组的长度是否满足条件。
  • 记录分组:当分组长度满足条件时,将其记录下来,并重置 startend 为当前字符的位置。
  • 处理最后一个分组:在遍历结束后,检查最后一个分组是否满足条件。
  • 排序结果:将结果按起始位置排序后返回。
  • 解决代码

    import java.util.ArrayList;import java.util.List;class Solution {    public List
    > largeGroupPositions(String s) { List
    > res = new ArrayList<>(); int start = 0; int end = 0; for (int i = 1; i < s.length(); i++) { if (s.charAt(i) == s.charAt(i - 1)) { end++; } else { if (end - start + 1 >= 3) { res.add(new ArrayList<>()); res.get(res.size() - 1).add(start); res.get(res.size() - 1).add(end); } start = end + 1; end = start; } } // 处理最后一个分组 if (end - start + 1 >= 3) { res.add(new ArrayList<>()); res.get(res.size() - 1).add(start); res.get(res.size() - 1).add(end); } return res; }}

    代码解释

  • 初始化变量startend 初始化为 0,用于记录当前分组的起始和结束位置。
  • 遍历字符串:从第二个字符开始遍历。如果当前字符和前一个字符相同,继续当前分组,否则检查当前分组长度。
  • 记录分组:当分组长度大于等于 3 时,记录分组的起始和结束位置,并重置 startend 为当前字符的位置。
  • 处理最后一个分组:在遍历结束后,检查最后一个分组是否满足条件,并记录。
  • 返回结果:将结果按起始位置排序后返回。
  • 这个方法确保了我们能准确地找到所有较大分组,并按要求排序返回结果。

    转载地址:http://dejmz.baihongyu.com/

    你可能感兴趣的文章
    pip throws TypeError: parse() got an unexpected keyword argument ‘transport_encoding‘ 在尝试安装新软件包时
    查看>>
    pip 下载慢
    查看>>
    pip 升级报错AttributeError: ‘NoneType’ object has no attribute ‘bytes’
    查看>>
    pip 安装opencv-python卡死
    查看>>
    pip 安装出现异常
    查看>>
    Pip 安装失败:需要 SSL
    查看>>
    Pip 安装挂起
    查看>>
    pip 或 pip3 为 Python 3 安装包?
    查看>>
    pip 文件损坏导致 pip无法使用 报错 ImportError: cannot import name 'main' from 'pip._int
    查看>>
    pip 无法从 requirements.txt 安装软件包
    查看>>
    pip/pip3更换国内源
    查看>>
    pip3 install PyQt5 --user 失败
    查看>>
    pip3命令全解析:Python3包管理工具的详细使用指南
    查看>>
    pip3安装命令重复创建文件‘/tmp/pip-install-xxxxx/package‘失败
    查看>>
    PIPE 接口信号列表
    查看>>
    pipeline配置与管理Job企业级实战
    查看>>
    pipeline项目配置实战
    查看>>
    Pipenv 与 Conda?
    查看>>
    QVGA/HVGA/WVGA/FWVGA分辨率屏含义及大小//Android虚拟机分辨率
    查看>>
    pipreqs : 无法将“pipreqs”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径 正确,然后再试一次。
    查看>>