在Java中如何高效判断数组中是否包含某个元素
在Java中如何高效判断数组中是否包含某个元素?下面就跟着千锋重庆Java培训老师一起来看看!
如何检查一个数组(无序)是否包含一个特定的值?这是一个在Java中经常用到的并且非常有用的操作。同时,这个问题在Stack Overflow中也是一个非常热门的问题。在投票比较高的几个答案中给出了几种不同的方法,但是他们的时间复杂度也是各不相同的。本文将分析几种常见用法及其时间成本。
检查数组是否包含某个值的方法
使用List
public static boolean useList(String[] arr, String targetValue) {
return Arrays.asList(arr).contains(targetValue);}
使用Set
public static boolean useSet(String[] arr, String targetValue) {
Setset = new HashSet(Arrays.asList(arr));
return set.contains(targetValue);}
使用循环判断
public static boolean useLoop(String[] arr, String targetValue) {
for(String s: arr){
if(s.equals(targetValue))
return true;
}
return false;
使用Arrays.binarySearch()
Arrays.binarySearch()方法只能用于有序数组!!!如果数组无序的话得到的结果就会很奇怪。
查找有序数组中是否包含某个值的用法如下:
public static boolean useArraysBinarySearch(String[] arr, String targetValue) {
int a = Arrays.binarySearch(arr, targetValue);
if(a > 0)
return true;
else
return false;}
时间复杂度
下面的代码可以大概的得出各种方法的时间成本。基本思想就是从数组中查找某个值,数组的大小分别是5、1k、10k。这种方法得到的结果可能并不精确,但是是最简单清晰的方式。
public static void main(String[] args) {
String[] arr = new String[] { "CD", "BC", "EF", "DE", "AB"};
//use list
long startTime = System.nanoTime();
for (int i = 0; i < 100000; i++) {
useList(arr, "A");
}
long endTime = System.nanoTime();
long duration = endTime - startTime;
System.out.println("useList: " + duration / 1000000);
//use set
startTime = System.nanoTime();
for (int i = 0; i < 100000; i++) {
useSet(arr, "A");
}
endTime = System.nanoTime();
duration = endTime - startTime;
System.out.println("useSet: " + duration / 1000000);
//use loop
startTime = System.nanoTime();
for (int i = 0; i < 100000; i++) {
useLoop(arr, "A");
}
endTime = System.nanoTime();
duration = endTime - startTime;
System.out.println("useLoop: " + duration / 1000000);
//use Arrays.binarySearch()
startTime = System.nanoTime();
for (int i = 0; i < 100000; i++) {
useArraysBinarySearch(arr, "A");
}
endTime = System.nanoTime();
duration = endTime - startTime;
System.out.println("useArrayBinary: " + duration / 1000000);}
运行结果:
useList: 13useSet: 72useLoop: 5useArraysBinarySearch: 9
使用一个长度为1k的数组
String[] arr = new String[1000];Random s = new Random();for(int i=0; i< 1000; i++){
arr[i] = String.valueOf(s.nextInt());}
结果:
useList: 112useSet: 2055useLoop: 99useArrayBinary: 12
使用一个长度为10k的数组
String[] arr = new String[10000];Random s = new Random();for(int i=0; i< 10000; i++){
arr[i] = String.valueOf(s.nextInt());}
结果:
useList: 1590useSet: 23819useLoop: 1526useArrayBinary: 12
总结
显然,使用一个简单的循环方法比使用任何集合都更加高效。许多开发人员为了方便,都使用第一种方法,但是他的效率也相对较低。因为将数组压入Collection类型中,首先要将数组元素遍历一遍,然后再使用集合类做其他操作。
如果使用Arrays.binarySearch()方法,数组必须是已排序的。由于上面的数组并没有进行排序,所以该方法不可使用。
实际上,如果你需要借助数组或者集合类高效地检查数组中是否包含特定值,一个已排序的列表或树可以做到时间复杂度为O(log(n)),hashset可以达到O(1)。
使用ArrayUtils
除了以上几种以外,Apache Commons类库中还提供了一个ArrayUtils类,可以使用其contains方法判断数组和值的关系。
import org.apache.commons.lang3.ArrayUtils;public static boolean useArrayUtils(String[] arr, String targetValue) {
return ArrayUtils.contains(arr,targetValue);}
同样使用以上几种长度的数组进行测试,得出的结果是该方法的效率介于使用集合和使用循环判断之间(有的时候结果甚至比使用循环要理想)。
useList: 323useSet: 3028useLoop: 141useArrayBinary: 12useArrayUtils: 181-------useList: 3703useSet: 35183useLoop: 3218useArrayBinary: 14useArrayUtils: 3125
如果对Java感兴趣,不妨来千锋重庆Java培训进行两周的免费试听,全程面授的高品质教学模式,让你系统掌握Java技术!

猜你喜欢LIKE
相关推荐HOT
更多>>
前端工程师需要掌握哪些知识?前端主流框架是什么?
Web前端在最近几年发展的十分迅速,企业需求量越来越大,自然开出的薪资待遇也水涨船高,吸引越来越多的人学习前端技术,甚至有的人自学前端。...详情>>
2023-03-17 14:58:14
重庆前端开发培训班学出来有用吗?自学能成吗?
前端开发如今的市场份额占比十分大,岗位人才缺口还是比较大,自然进军前端开发的人也多了起来。有人说前端开发入门容易,可以自学,也有人建议...详情>>
2023-03-16 14:24:17
重庆学it到哪里比较好?it培训机构靠谱吗?
IT行业的发展非常迅速,随着科技的进步和人工智能的应用,IT技术不再如旧时一样神秘难学,可以通过培训短时间内从零基础学会一门it技术。尽管如...详情>>
2023-03-13 11:36:54
学软件开发哪里好?在重庆如何选择一家专业的培训?
学软件开发哪里好?随着软件开发技术的蓬勃发展,衍生出了不少的it技术培训机构,对于想要参加培训的同学而言,在选择上无疑是非常困难的。学软...详情>>
2023-03-09 15:47:39热门推荐
学it行业需要什么学历?重庆it培训哪比较好?
沸java和python的区别与联系,初学者适合学哪个?
热java培训学校出来好找工作吗?Java程序员的出路好吗?
热Java如何学?有什么技巧?
新前端工程师需要掌握哪些知识?前端主流框架是什么?
学it培训班哪个好?线上it培训班怎么样?
重庆java培训一般几个月?零基础能转行学习吗?
学it需要具备什么条件?IT行业容易进吗?
web前端怎么学?零基础学前端要多久?
重庆前端开发培训班学出来有用吗?自学能成吗?
学it需要多长时间?重庆it培训班真的能就业吗?
学it需要什么学历?最低要求是什么?
java开发需要学习什么?Java怎样快速入门?
现在it行业哪个方向比较好?转行做IT好吗?
技术干货






