zoukankan      html  css  js  c++  java
  • LeetCode 830. Positions of Large Groups

    In a string S of lowercase letters, these letters form consecutive groups of the same character.

    For example, a string like S = "abbxxxxzyy" has the groups "a""bb""xxxx""z" and "yy".

    Call a group large if it has 3 or more characters.  We would like the starting and ending positions of every large group.

    The final answer should be in lexicographic order.

    Example 1:

    Input: "abbxxxxzzy"
    Output: [[3,6]]
    Explanation: "xxxx" is the single large group with starting  3 and ending positions 6.
    

    Example 2:

    Input: "abc"
    Output: []
    Explanation: We have "a","b" and "c" but no large group.
    

    Example 3:

    Input: "abcdddeeeeaabbbcd"
    Output: [[3,5],[6,9],[12,14]]

    Note:  1 <= S.length <= 1000

    这道题本质上是在求字符串中连续重复3次及以上的子串首位位置,看上去不难,其实还是有很多坑在里面。比较直接的思路就是从头到尾遍历,一边遍历一边统计,但是要注意——这个思路最大的坑就是当一个字符串最后的3个字符是重复的时,无法将其返回到答案中。比如测试用例为“bbbaaaaa”,或者“aaaa”最后4个a的统计结果无法被返回,我最开始的解决思路是单独枚举字符串末尾出现重复变量的例子,但是后来我发现情况太多根本没有办法枚举完。于是我在外层for循环上做了点修改,多遍历一次,在内部用个if做判断,问题得到解决

     1 class Solution {
     2 public:
     3     vector<vector<int>> largeGroupPositions(string S) {
     4         vector<vector<int>> res;
     5         if (S.size() < 3)
     6             return res;
     7         /*if (S.size() == 3 && S[0] == S[1] && S[1] == S[2])
     8         {
     9             res.push_back({ 0,2 });
    10             return res;
    11         }
    12         if (S.size() == 4 && S[0] == S[1] && S[1] == S[2] && S[2] == S[3])
    13         {
    14             res.push_back({ 0,2 });
    15             return res;
    16         }*/
    17         int start = 0;
    18         int len = 0;  // the length of group
    19         for (int i = 0; i <= S.size(); i++)
    20         {
    21             //vector<int> temp;
    22             if (i != S.size())
    23             {
    24                 if (S[i] == S[start])
    25                 {
    26                     len++;
    27                     continue;
    28                 }
    29                 if (len >= 3)
    30                 {
    31                     res.push_back({ start,start + len - 1 });
    32                     len = 1;
    33                     start = i;
    34                 }
    35                 else
    36                 {
    37                     len = 1;
    38                     start = i;
    39                 }
    40             }
    41             else
    42             {
    43                 if (len >= 3)
    44                     res.push_back({ start,start + len - 1 });
    45             }
    46             
    47         }
    48         return res;
    49     }
    50 };
  • 相关阅读:
    腾讯2面
    腾讯1面
    快手2面
    快手1面
    formData+ajax文件上传
    nginx限流&健康检查
    jvm crash分析
    Spring Cloud Gateway整合Eureka
    k8s-应用部署
    dockerfile-maven plugin自动镜像制作并发布
  • 原文地址:https://www.cnblogs.com/dapeng-bupt/p/8997756.html
Copyright © 2011-2022 走看看