​力扣解法汇总面试题 17.05. 字母与数字
创始人
2025-05-29 00:03:03

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣


描述:

给定一个放有字母和数字的数组,找到最长的子数组,且包含的字母和数字的个数相同。

返回该子数组,若存在多个最长子数组,返回左端点下标值最小的子数组。若不存在这样的数组,返回一个空数组。

示例 1:

输入: ["A","1","B","C","D","2","3","4","E","5","F","G","6","7","H","I","J","K","L","M"]输出: ["A","1","B","C","D","2","3","4","E","5","F","G","6","7"]

示例 2:

输入: ["A","A"]输出: []

提示:

  • array.length <= 100000

解题思路:

* 解题思路:
* 记录每个位置charNum-intNum的值,按照这个值来分组,满足统一条件的两个位置相减,就是符合条件的子数组。
* 构建一个Map>的结构,某个位置charNum-intNum的结果,value为满足这个结果的所有位置的集合。
* 这里要特别注意一下diff=0的情况,0的话时候额外填充一个0。
* 然后遍历map的value,取出集合,集合的最后一位减去第一位,就是满足条件的长度。求最长。

代码:

public class MianShi1705 {public String[] findLongestSubarray(String[] array) {Map> map = new HashMap<>();int intNum = 0;int charNum = 0;for (int i = 0; i < array.length; i++) {String s = array[i];char c = s.toCharArray()[0];if ((c >= 'A' && c <= 'Z') || c >= 'a' && c <= 'z') {charNum++;} else {intNum++;}int diff = charNum - intNum;List integers = obtainQueue(map, diff);if (diff == 0 && integers.size() == 0) {integers.add(0);}integers.add(i + 1);}int maxLength = 0;int maxStart = 0;int maxEnd = 0;for (int key : map.keySet()) {List list = map.get(key);if (list.size() == 0) {continue;}int length;if (list.size() == 1) {continue;}length = list.get(list.size() - 1) - list.get(0);if (length > maxLength || (length == maxLength && list.get(0) < maxStart)) {maxLength = length;maxStart = list.get(0);maxEnd = list.get(list.size() - 1);}}if (maxLength == 0) {return new String[0];}String[] strings = Arrays.copyOfRange(array, maxStart, maxEnd);return strings;}private List obtainQueue(Map> map, int key) {List integers = map.get(key);if (integers == null) {integers = new ArrayList<>();map.put(key, integers);}return integers;}}

相关内容

热门资讯

年入10亿的网红按摩仪,要IP... “健康焦虑”这个赛道,挺魔幻的。作者 |渡尘来源 |投资家(ID:touzijias)“健康焦虑”这...
康乐卫士:子公司所欠中信银行昆... 新京报贝壳财经讯(记者黄鑫宇)12月20日,北交所上市公司北京康乐卫士生物技术股份有限公司(即“康乐...
觅睿科技“纽带式”股权激励:“... 本文来源:时代商业研究院 作者:彭元重来源|时代商业研究院作者|彭元重编辑|郑琳前有同行IPO折戟,...
港股打新亏钱!4只新股集体破发... 年底港股新股市场出现罕见一幕,今日港股四只新股上市首日集体破发。截至收盘,明基医院(02581.HK...
或冲刺第四家股份行AIC!光大... 全文共1293字,阅读全文约需3分钟据国家金融监管总局发布的《关于进一步扩大金融资产投资公司股权投资...