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

山西省建设厅网站见证员证书宋来增wordpress主题熊掌号

山西省建设厅网站见证员证书宋来增,wordpress主题熊掌号,二级域名网站有哪些,兰州关键词排名公司题目链接 面试题 17.05. 字母与数字 mid 题目描述 给定一个放有字母和数字的数组,找到最长的子数组,且包含的字母和数字的个数相同。 返回该子数组,若存在多个最长子数组,返回左端点下标值最小的子数组。若不存在这样的数组&…

题目链接

面试题 17.05. 字母与数字 mid

题目描述

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

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

示例 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≤100000array.length \leq 100000array.length100000

分析:前缀和 + 哈希表

我们可以将 字母看作是 +1,数字看作是 -1,那么原问题就转换为 求最长的一段和 sum = 0的子数组

我们用一个哈希表 m来记录遍历过的 前缀和 s[i]和它对应的下标 i

如果当前遍历到了 s[j],并且 m存在 s[j]这个键。由此,我们可以得到 i = m[s[j]]。那么 (i , j]这一段就是和为 0

的子数组,我们就将答案更新即可。

我们用 idx代表最长的那段子数组的起始下标,用 len表示最长的那段子数组的长度。

最后返回 array的这一段 [idx , idx + len]即可。

时间复杂度: O(n)O(n)O(n)

C++代码:

class Solution {
public:vector<string> findLongestSubarray(vector<string>& arr) {int n = arr.size();unordered_map<int,int> m{{0,-1}};int idx = 0 , len  = 0;for(int j = 0 ,s = 0;j < n;j++){s += (arr[j][0] >= 'A' ? 1 : -1);if(m.count(s)){int i = m[s];if(j - i > len){len = j - i;idx = i + 1;}}else m[s] = j;}return vector<string> (arr.begin() + idx,arr.begin() + idx + len);}
};

Python代码:


class Solution:def findLongestSubarray(self, arr: List[str]) -> List[str]:m = {0:-1}s = idx = len = 0for j,str in enumerate(arr):s += 1 if str.isalpha() else -1if s in m:i = m[s]if len < j - i:idx = i + 1len = j - ielse:m[s] = j    return arr[idx:idx+len]
http://www.15wanjia.com/news/187048.html

相关文章:

  • 企业管理咨询网站模板受欢迎的广州网站设计
  • 吴江网站建设深圳专业高端网站建设
  • 太原市建设路小学网站做网站哪家强
  • 网站建设的实验原理和方法建筑业资质查询网站
  • 东莞 网站制作建设银行手机不用了怎么登陆网站
  • 上海虹桥站配置wordpress
  • ps制作博客网站界面wordpress 页面路由
  • html网站后台管理系统seo价格
  • 沈阳市城市建设管理局网站内网代理ip建设网站
  • 网站建设按钮秦皇岛网站推广报价
  • 郴州公司做网站班级网站建设php
  • 上海网站建站模板南昌住房城市建设支行官方网站
  • 电器网站建设流程网站提供哪些服务
  • 信誉好的永州网站建设wordpress文章怎么分页
  • 自建站做seowordpress怎么改电子邮箱
  • 深圳设计网站排行网站域名的管理密码如何索取
  • 公司建站详细步骤大连网络推广运营
  • wordpress中文网站模板下载wordpress query post
  • 监理网站建设价格多少动易网站模板
  • 如何做充值网站广州自助建站
  • 开花店做网站新站网站建设
  • 网站没有做适配 怎么办哈巴狗模式网站开发
  • 济南手机网站建设报价百度全网营销
  • 织梦网站统计代码巨鹿网站制作
  • 福州网站建设找时时在网络怎样临沂网站建设
  • 网站如何做信誉认证免注册个人网站制作
  • 网站制作的服务商广州网站公司建设
  • 贵州安顺建设局网站编程是什么
  • 手机兼职平台网站开发国外做网站推广
  • 中国建设企业银行网站首页遵义做网站公司