Leetcode--763. 划分字母区间

字符串 S 由小写字母组成。我们要把这个字符串划分为尽可能多的片段,同一个字母只会出现在其中的一个片段。返回一个表示每个字符串片段的长度的列表。

 

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

 

提示:

S的长度在[1, 500]之间。
S只包含小写字母 'a' 到 'z' 。

 

思路:看到题目先想到了把S拆成两段(如果S可划分),之后把拆开的S分段再进行拆分(如果可拆分),如果不可拆分就把当前分段

的长度写入结果链表

1.怎么判断是不是可拆分?

先保存当前字符串各字符数量(用map,数组都可以),之后复制一下先前统计的结果,然后从头开始遍历,执行--操作。如果当前字符的数量为0,那就说明该字符只出现在当前字符与当前字符前面,这个字符是可以拆分的,开始看他前面的字符是不是都可以拆分,如果他前面的字符当前的数量不为0,说明后面还有,继续向下遍历。如果当前字符前面的字符的也都不出现在后面,说明该字段可以拆分。

2.实现

可拆分:继续拆

不可拆分:当前字符长度保存进结果链表

代码:

class Solution {List<Integer> result = new ArrayList<>();void chaifen(String s){if(s.length()==0){return ;}int arr[] = new int[26];//统计各字符出现的次数for(int i=0;i<s.length();i++){arr[s.charAt(i)-'a']+=1;}int brr[] = arr;int index = 0;for(int i=0;i<s.length();i++){brr[s.charAt(i)-'a']-=1;int j=0;//当前字符的数量为0,说明不会出现在后面了if(brr[s.charAt(i)-'a']==0){//检索前面的字符是不是也都不会出现在后面for(j=0;j<=i;j++){if(brr[s.charAt(j)-'a']!=0){break;}}}//index记录可以拆分的位置,如果不可拆分,位置就是字符串尾部if(j>i){index = i;break;}}if(index!=s.length()-1){chaifen(s.substring(0,index+1));chaifen(s.substring(index+1,s.length()));}else{result.add(s.length());}}public List<Integer> partitionLabels(String S) {chaifen(S);return result;}
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/484861.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学术交流丨魏子卿院士:北斗坐标系

来源&#xff1a;微信公众号中国测绘学会引文格式&#xff1a;魏子卿, 吴富梅, 刘光明. 北斗坐标系[J]. 测绘学报&#xff0c;2019&#xff0c;48(7)&#xff1a;805-809. DOI: 10.11947/j.AGCS.2019.20190131第一作者&#xff1a;魏子卿&#xff08;中国工程院院士&#xff0c…

【原创】论码农的财富修养

《喜剧之王》里看到了演员的自我修养&#xff0c;然后想聊下码农的财富修养&#xff0c;这里不是聊理财&#xff0c;更多是保险Insurance&#xff1b;保险是什么&#xff0c;是一种通过支付少量的保险费用来应对未知风险的机制&#xff0c;比如车险、财险、健康险等&#xff1b…

centos 安装MySQL报错You could try using --skip-broken to work around the problem You could try running:

centos 安装MySQL报错You could try using --skip-broken to work around the problem You could try running: rpm -Va --nofiles --nodigest wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-community-release-el7-5.noarch.rpm yum …

Java中序列化的好处及意义

1、序列化是干什么的&#xff1f;简单说就是为了保存在内存中的各种对象的状态&#xff0c;并且可以把保存的对象状态再读出来。虽然你可以用你自己的各种各样的方法来保存Object States&#xff0c; 但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。2…

​马斯克的全球上网计划:月费646元,网速可达200Mbps

SpaceX创始人兼首席执行官埃隆马斯克来源&#xff1a;腾讯科技审校作者&#xff1a;金鹿腾讯科技讯 4月16日消息&#xff0c;美国太空探索技术公司SpaceX在六个月前向公众推出了Starlink Early Access计划。在最初的几个月里&#xff0c;这项卫星互联网服务的用户增长到了1万多…

剑指 Offer 68 - II. (二叉树)二叉树的最近公共祖先

题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个结点 p、q&#xff0c;最近公共祖先表示为一个结点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&#xff08;一个节点也可以…

从狼群智能到无人机群协同决策

来源&#xff1a;飞思实验室文&#xff1a;小翼生物群集行为是自然界存在的一种普遍现象 ,先前的研究已表明人们可以通过模仿鸟群、鱼群、蜂群等行为, 研究其群体性决策机制, 进而用于构建集群系统的决策系统框架. 狼群在认知、分工, 以及复杂环境适应性等方面具有突出的优势, …

解决问题 com.alibaba.fastjson.JSONObject cannot be cast to xxx

{"msg": "success","code": "success","data": [{"create_time": "2020-11-09 11:54:08","exec_status": "正常","host_id": 1527414,"id": 3136268,"ip…

CSS常用样式

边框 http://www.w3school.com.cn/cssref/pr_border.asp p {border:5px solid red; } 可以按顺序设置如下属性&#xff1a; border-width border-style border-colorobject.style.border"3px solid blue"边框阴影(CSS3 ) http://www.w3school.com.cn/cssref/pr_box-s…

华为自动驾驶实车实路测试视频曝光!

来源&#xff1a;量子位、物联网智库等自动驾驶的风又刮起来了&#xff0c;这次处在风暴中心的是华为。4月15日&#xff0c;消息称配备华为自动驾驶技术的北汽新能源极狐阿尔法S的HI版车型在上海进行了公开试乘&#xff0c;这也是华为自动驾驶技术公开试乘的全球首秀。就试乘效…

Leetcode--450. 删除二叉搜索树中的节点

给定一个二叉搜索树的根节点 root 和一个值 key&#xff0c;删除二叉搜索树中的 key 对应的节点&#xff0c;并保证二叉搜索树的性质不变。返回二叉搜索树&#xff08;有可能被更新&#xff09;的根节点的引用。 一般来说&#xff0c;删除节点可分为两个步骤&#xff1a; 首先…

未来智能:人有人用,机有机用

来源&#xff1a; 苇草智酷作者&#xff1a;王飞跃当今最好的人工智能程序到底有多智能&#xff1f;它们是如何工作的&#xff1f;能做些什么&#xff1f;我们有必要担心机器比人类聪明且将很快夺取我们的工作吗&#xff1f;以上这些问题都颇受人们的关注&#xff0c;梅拉妮米歇…

Leetcode--329. 矩阵中的最长递增路径

给定一个整数矩阵&#xff0c;找出最长递增路径的长度。 对于每个单元格&#xff0c;你可以往上&#xff0c;下&#xff0c;左&#xff0c;右四个方向移动。 你不能在对角线方向上移动或移动到边界外&#xff08;即不允许环绕&#xff09;。 示例 1: 输入: nums [ [9,9,…

排序及查找----[(冒泡,快速)(拉格朗日,二分)]

代码展示: 1 using System;2 using System.Collections.Generic;3 using System.Linq;4 using System.Text;5 using System.Threading.Tasks;6 7 namespace paixu8 {9 class Program10 {11 static void Main()12 {13 int[] Array { 1, 45…

因果作用推断、因果网络学习及其他

来源&#xff1a;久章智能 未来智能实验室的主要工作包括&#xff1a;建立AI智能系统智商评测体系&#xff0c;开展世界人工智能智商评测&#xff1b;开展互联网&#xff08;城市&#xff09;云脑研究计划&#xff0c;构建互联网&#xff08;城市&#xff09;云脑技术和企业图谱…

学习《图解HTTP》有感

HTTP协议的出现主要是为了解决文本传输的难题&#xff08;大家互相共享文件没有一个规范&#xff09;&#xff0c;最初的设计理念是&#xff1a;借助多文档之间的关联形成超文本&#xff0c;成为相互参阅的WWW&#xff08;万维网&#xff09; 计算机和网络设备要通信&#xff…

mysql解决select * from 表名 (where + 约束条件为空)

mysql解决select * from 表名 (where 约束条件为空)&#xff0c;示例如下&#xff1a; SELECT * from tableName WHERE name is NULL; 从 tableName 表中查询 name 字段为空的记录。转载于:https://www.cnblogs.com/zrmw/p/9887655.html

通信人工智能的下一个十年(上)

来源&#xff1a;电信科学欧阳晔1, 王立磊1, 杨爱东1, 马利克萨哈2, 大卫贝兰格3,4, 高同庆5, 韦乐平6, 张亚勤71 亚信科技&#xff08;中国&#xff09;有限公司&#xff0c;北京 1001932 美国威瑞森电信公司&#xff0c;美国 纽约 100363 美国电话电报公司&#xff0c;美国 得…

[Swift]LeetCode19. 删除链表的倒数第N个节点 | Remove Nth Node From End of List

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号&#xff1a;山青咏芝&#xff08;shanqingyongzhi&#xff09;➤博客园地址&#xff1a;山青咏芝&#xff08;https://www.cnblogs.com/strengthen/&#xff09;➤GitHub地址&a…

CAS

cas&#xff1a;Compare and Swap&#xff0c;即比较再交换。 对CAS的理解&#xff0c;CAS是一种无锁算法&#xff0c;CAS有3个操作数&#xff0c;内存值V&#xff0c;旧的预期值A&#xff0c;要修改的新值B。当且仅当预期值A和内存值V相同时&#xff0c;将内存值V修改为B&…