力扣面试题 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)

相关推荐
NFA晨曦几秒前
力扣刷题日常(7-8)
算法·leetcode·c#
小指纹1 小时前
图论-最短路 Bellman-Ford算法
c++·算法·objective-c·图论
屁股割了还要学1 小时前
【数据结构入门】时间、空间复杂度的计算
c语言·开发语言·数据结构·c++·算法
myjs9991 小时前
数学=符号
java·前端·算法
麦兜*2 小时前
大模型时代,Transformer 架构中的核心注意力机制算法详解与优化实践
jvm·后端·深度学习·算法·spring·spring cloud·transformer
coding随想2 小时前
算法界的“达摩克利斯之剑”——NP完全性理论
算法
秋难降3 小时前
栈:从基础概念到实战解题(详细)
数据结构·算法·排序算法
ezl1fe3 小时前
RAG 每日一技(十):向量检索的“死穴”?用混合搜索(Hybrid Search)来拯救!
后端·算法
Ahu_iii3 小时前
【图论基础】理解图的“闭环”:Tarjan 强连通分量算法全解析
算法·图论
PixelMind3 小时前
【IQA技术专题】DISTS代码讲解
图像处理·人工智能·python·算法·iqa