当前位置: 首页 > news >正文

专注东莞微信网站建设东莞网络营销代运营

专注东莞微信网站建设,东莞网络营销代运营,wordpress 登录限制,微商软件自助商城给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。 注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。 返回一个表示每个字符串片段的长度的列表。 示例 1&a…

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。

注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。

返回一个表示每个字符串片段的长度的列表。

示例 1:

输入:s = “ababcbacadefegdehijhklij”
输出:[9,7,8]
解释:
划分结果为 “ababcbaca”、“defegde”、“hijhklij” 。
每个字母最多出现在一个片段中。
像 “ababcbacadefegde”, “hijhklij” 这样的划分是错误的,因为划分的片段数较少。

示例 2:

输入:s = “eccbbbbdec”
输出:[10]

提示:

1 < = s . l e n g t h < = 500 1 <= s.length <= 500 1<=s.length<=500
s 仅由小写英文字母组成


思路:

  • 初始化遍历字符串中的字符,求出每个字符在字符串中最右的下标
  • 遍历字符串中的字符,确定一个区间,使得区间中的字串,满足区间内每一个字母最只出现在当前区间中
    • 用 l/r 标识当前区间的左/右边界下标,如果当前字符的下标 > r,则将 [l.r] 加入 res 结果中,更新 l 和 r
    • 否则,更新 r 下标
  • 对于 r,如果当前字符在整个字符串中的最右边界 > 当前子区间的 r 边界,则用其更新 r
class Solution {
public:int rmax[30];vector<int> partitionLabels(string s) {int n = s.size();for(int i = 0; i < n; i++){rmax[s[i]-'a'] = max(rmax[s[i]-'a'], i);}vector<int> res;int l = -1, r = -1;for(int i = 0; i < n; i++){if(i > r){if(i) res.push_back(r - l + 1);l = i;}r = max(r, rmax[s[i]-'a']);}res.push_back(r - l + 1);return res;}
};
http://www.tj-hxxt.cn/news/59816.html

相关文章:

  • 蒲城县住房和城乡建设局网站十大互联网广告公司
  • 做模板网站推荐乐云seo鸡西网站seo
  • 网站建设在家兼职做沈阳高端关键词优化
  • 网上帮做一些小事赚零花钱的网站企点官网
  • 建站工具包友链网站
  • 上海智能网站建设公司写一篇软文多少钱
  • 沈阳公司网站广州做seo的公司
  • 做二手网站域名购买
  • 做网站流量赚钱淘宝权重查询入口
  • wordpress 网站搬迁广州全网推广
  • 外链网站有哪些全网推广平台
  • 呼和浩特做网站怎么制作网页设计
  • wordpress 安装500重庆网站seo教程
  • 如何做好商务网站的运营怎么做旺道seo怎么优化网站
  • 网站建设与管理学什么seo工具包括
  • 最好的汽车科技网站建设网建
  • 平谷住房和城乡建设委员会网站长春百度推广排名优化
  • 网站访问找不到域名怎么回事常德今日头条新闻
  • wordpress开通多站点好处首页关键词排名代发
  • 2003访问网站提示输入用户名密码搜狗广告联盟
  • 对一个网站怎么做攻击测试广州百度seo优化排名
  • seo网站提交提交培训班报名
  • 西安做网站哪里便宜十大网络推广公司排名
  • 手机宣传网站app安装下载
  • asp.net 网站开发百度电话怎么转人工
  • 国际人才网app搜索引擎优化的工具
  • 网站开发程序员岗位职责网站数据统计
  • 网站怎么做不换行文字代码现在学seo课程多少钱
  • 上海找人做网站怎么注册自己的网站
  • 备案的网站程序上传网络营销策略的定义