Java中高效的判断数组中某个元素是否存在详解

一、检查数组是否包含某个值的方法

使用List

public static boolean useList(String[] arr, String targetValue) {
  return Arrays.asList(arr).contains(targetValue);
}

使用Set

public static boolean useSet(String[] arr, String targetValue) {
  Set set = 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;
}

你可能感兴趣的:(Java中高效的判断数组中某个元素是否存在详解)