ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

NC41 最长无重复子数组

2021-09-28 11:34:32  阅读:125  来源: 互联网

标签:map arr int 重复子 length 数组 maxLength NC41


package NC;

import java.util.*;

/**
* NC41 最长无重复子数组
*
* 给定一个数组arr,返回arr的最长无重复元素子数组的长度,无重复指的是所有数字都不相同。
* 子数组是连续的,比如[1,3,5,7,9]的子数组有[1,3],[3,5,7]等等,但是[1,3,7]不是子数组
*
* 要求:空间复杂度O(n) ,时间复杂度O(logn)
*
* @author Tang
* @date 2021/9/28
*/
public class MaxLength {

/**
* 找到以每个元素开头的无重复长度
* 比较出最大长度
* (时间复杂度较大,空间复杂度一般)
*
* @param arr
* @return
*/
public int maxLength (int[] arr) {
// write code here

int maxLength = 0;

Map<Integer, Integer> map = new HashMap<>();

//每次遍历算出以i开始的连续最长串
for(int i = 0; i < arr.length; i++) {
int length = 1;
map.put(arr[i], i);

for(int j = i+1; j < arr.length; j++) {
if(map.containsKey(arr[j])) {
break;
}
length++;
map.put(arr[j], j);
}
maxLength = Math.max(maxLength, length);
map.clear();
}
return maxLength;

}


public static void main(String[] args) {


}


}

标签:map,arr,int,重复子,length,数组,maxLength,NC41
来源: https://www.cnblogs.com/ttaall/p/15347048.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有