zoukankan      html  css  js  c++  java
  • Java学习--数组--判断数组中是否包含某个元素的方法

    package zaLearnpackage;
    import org.apache.commons.lang3.ArrayUtils;
    import java.util.Arrays;
    import java.util.HashSet;
    import java.util.Set;
    
    //检查数组是否包含某个值的方法
    public class TestArray {
        //使用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<String> set=new HashSet<String>(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;
        }
        //查找有序数组中是否包含某个值的用法
        public static boolean useArraysBinarySearch(String[] arr,String targetValue){
            int a=Arrays.binarySearch(arr, targetValue);
            if(a>0)
                return true;
            else
                return false;
        }
        //使用ArrayUtils
        public static boolean useArrayUtils(String[] arr,String targetValue){
            return ArrayUtils.contains(arr,targetValue);
        }
        public static void main(String[] args) {
            String[] arr=new String[]{"CD","BC","EF","DE","AB","JK"};
            //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
            long startTime2=System.nanoTime();
            for(int i=0;i<100000;i++){
                useSet(arr, "A");
            }
            long endTime2=System.nanoTime();
            long duration2=endTime2-startTime2;
            System.out.println("useSet:"+duration/1000000);
            //use loop
            long startTime3=System.nanoTime();
            for(int i=0;i<100000;i++){
                useLoop(arr, "A");
            }
            long endTime3=System.nanoTime();
            long duration3=endTime3-startTime3;
            System.out.println("useLoop:"+duration/1000000);
            //use Arrays.binarySearch()
            long startTime4=System.nanoTime();
            for(int i=0;i<100000;i++){
                useArraysBinarySearch(arr, "A");
            }
            long endTime4=System.nanoTime();
            long duration4=endTime4-startTime4;
            System.out.println("useArraysBinarySearch:"+duration/1000000);
        }
    }
    /*
     * 显然,使用一个简单的循环方法比使用任何集合都更加高效。
     * 许多开发人员为了方便,都使用第一种方法,但是他的效率也相对较低。
     * 因为将数组压入Collection类型中,首先要将数组元素遍历一遍,然后再使用集合类做其他操作。
     */
  • 相关阅读:
    打开CAD时出现“acvmtools.arx ARX命令中发生异常
    VS2010编译错: #error : This file requires _WIN32_WINNT to be #defined at least to 0x0403...的解决方法
    CAD中的相对坐标和绝对坐标
    CAD中的文本编排操作
    使用VS2008,VS2010编译64位的应用程序
    已知两切线和半径画圆弧和圆
    AutoCAD2012启动错误 1308 源文件未找到
    C++中的static修饰的变量和函数
    VS2010创建C++静态链接库创建和使用
    Python中同时用多个分隔符分割字符串的问题
  • 原文地址:https://www.cnblogs.com/gaoBlog/p/10773981.html
Copyright © 2011-2022 走看看