力扣面试题 17.05. 字母与数字

这一道题和
力扣525.连续数组

思路一模一样。

都是把其中一种看作-1,另一种看作1,这样转化为找前缀和为0的子数组,比较简单,哈希表+前缀和解决

c++class 复制代码
public:
  int sum[100005];
unordered_map<int,int> mp;
vector<string> findLongestSubarray(vector<string>& array) {
        for(int i=0;i<array.size();i++)
        {
        	if(array[i][0]>='0'&&array[i][0]<='9')
        	{
        		sum[i+1]=sum[i]-1;
			}
			else
			{
				sum[i+1]=sum[i]+1;
			}
        
		}
		mp[0]=0;
		int l=0;
		int r=0;
		int llmax=0;
		int rrmax=0;
		int maxx=0;
		for(int j=1;j<=array.size();j++)
		{
			if(mp.count(sum[j]))
			{
				r=j;
				l=mp[sum[j]];
				if(r-l>maxx)
				{
					maxx=r-l;
					llmax=l;
					rrmax=r;
				}
			}
			else
			{
				mp[sum[j]]=j;
			}
		}
      
        return vector<string>(array.begin()+llmax,array.begin()+rrmax);
        
        
        
    }
};

但这一道题要注意的是返回值,如上代码写,比较方便,应该掌握

时间复杂度O(n)

相关推荐
m0_640743561 小时前
华为OD-2024年E卷-字符串分割[100分] -- python
数据结构·算法·华为od
圣保罗的大教堂5 小时前
leetcode 2566. 替换一个数字后的最大差值 简单
leetcode
code喵喵7 小时前
八种数据结构简介
数据结构·算法·推荐算法
C语言小火车7 小时前
【C语言】银行账户管理系统丨源码+解析
c语言·c++·算法·课程设计
wen__xvn7 小时前
九日集训第三天
数据结构·算法·leetcode
dying_man7 小时前
LeetCode--33.搜索旋转排序数组
算法·leetcode
东方芷兰8 小时前
Leetcode 刷题记录 17 —— 堆
java·c++·b树·算法·leetcode·职场和发展
Cyrus_柯9 小时前
C++(面向对象编程)
开发语言·c++·算法·面向对象
wen__xvn9 小时前
九日集训第六天
数据结构·算法·leetcode