久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術(shù)干貨  > 在Java中如何高效判斷數(shù)組中是否包含某個元素

        在Java中如何高效判斷數(shù)組中是否包含某個元素

        來源:千鋒教育
        發(fā)布人:千鋒老師
        時間: 2018-12-19 13:24:00 1545197040

          如何檢查一個數(shù)組(無序)是否包含一個特定的值?這是一個在Java中經(jīng)常用到的并且非常有用的操作。同時,這個問題在Stack Overflow中也是一個非常熱門的問題。在投票比較高的幾個答案中給出了幾種不同的方法,但是他們的時間復(fù)雜度也是各不相同的。本文將分析幾種常見用法及其時間成本。

          檢查數(shù)組是否包含某個值的方法

          使用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);}

          使用循環(huán)判斷

          public static boolean useLoop(String[] arr, String targetValue) {

          for(String s: arr){

          if(s.equals(targetValue))

          return true;

          }

          return false;

          使用Arrays.binarySearch()

          Arrays.binarySearch()方法只能用于有序數(shù)組!!!如果數(shù)組無序的話得到的結(jié)果就會很奇怪。

          查找有序數(shù)組中是否包含某個值的用法如下:

          public static boolean useArraysBinarySearch(String[] arr, String targetValue) {

          int a = Arrays.binarySearch(arr, targetValue);

          if(a > 0)

          return true;

          else

          return false;}

          時間復(fù)雜度

          下面的代碼可以大概的得出各種方法的時間成本。基本思想就是從數(shù)組中查找某個值,數(shù)組的大小分別是5、1k、10k。這種方法得到的結(jié)果可能并不精確,但是是最簡單清晰的方式。

          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);}

          運行結(jié)果:

          useList: 13useSet: 72useLoop: 5useArraysBinarySearch: 9

          使用一個長度為1k的數(shù)組

          String[] arr = new String[1000];Random s = new Random();for(int i=0; i< 1000; i++){

          arr[i] = String.valueOf(s.nextInt());}

          結(jié)果:

          useList: 112useSet: 2055useLoop: 99useArrayBinary: 12

          使用一個長度為10k的數(shù)組

          String[] arr = new String[10000];Random s = new Random();for(int i=0; i< 10000; i++){

          arr[i] = String.valueOf(s.nextInt());}

          結(jié)果:

          useList: 1590useSet: 23819useLoop: 1526useArrayBinary: 12

          總結(jié)

          顯然,使用一個簡單的循環(huán)方法比使用任何集合都更加高效。許多開發(fā)人員為了方便,都使用第一種方法,但是他的效率也相對較低。因為將數(shù)組壓入Collection類型中,首先要將數(shù)組元素遍歷一遍,然后再使用集合類做其他操作。

          如果使用Arrays.binarySearch()方法,數(shù)組必須是已排序的。由于上面的數(shù)組并沒有進行排序,所以該方法不可使用。

          實際上,如果你需要借助數(shù)組或者集合類高效地檢查數(shù)組中是否包含特定值,一個已排序的列表或樹可以做到時間復(fù)雜度為O(log(n)),hashset可以達到O(1)。

          使用ArrayUtils

          除了以上幾種以外,Apache Commons類庫中還提供了一個ArrayUtils類,可以使用其contains方法判斷數(shù)組和值的關(guān)系。

          import org.apache.commons.lang3.ArrayUtils;public static boolean useArrayUtils(String[] arr, String targetValue) {

          return ArrayUtils.contains(arr,targetValue);}

          同樣使用以上幾種長度的數(shù)組進行測試,得出的結(jié)果是該方法的效率介于使用集合和使用循環(huán)判斷之間(有的時候結(jié)果甚至比使用循環(huán)要理想)。

          useList: 323useSet: 3028useLoop: 141useArrayBinary: 12useArrayUtils: 181-------useList: 3703useSet: 35183useLoop: 3218useArrayBinary: 14useArrayUtils: 3125

          其實,如果查看ArrayUtils.contains的源碼可以發(fā)現(xiàn),他判斷一個元素是否包含在數(shù)組中其實也是使用循環(huán)判斷的方式。

          部分代碼如下:

          if(array == null) {

          return -1;

          } else {

          if(startIndex < 0) {

          startIndex = 0;

          }

          int i;

          if(objectToFind == null) {

          for(i = startIndex; i < array.length; ++i) {

          if(array[i] == null) {

          return i;

          }

          }

          } else if(array.getClass().getComponentType().isInstance(objectToFind)) {

          for(i = startIndex; i < array.length; ++i) {

          if(objectToFind.equals(array[i])) {

          return i;

          }

          }

          }

          return -1;

          }

          所以,相比較之下,我更傾向于使用ArrayUtils工具類來進行一些合數(shù)祖相關(guān)的操作。畢竟他可以讓我少寫很多代碼(因為自己寫代碼難免有Bug,畢竟apache提供的開源工具類庫都是經(jīng)過無數(shù)開發(fā)者考驗過的),而且,效率上也并不低太多。

        tags:
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學 138****2860 剛剛成功領(lǐng)取
        王同學 131****2015 剛剛成功領(lǐng)取
        張同學 133****4652 剛剛成功領(lǐng)取
        李同學 135****8607 剛剛成功領(lǐng)取
        楊同學 132****5667 剛剛成功領(lǐng)取
        岳同學 134****6652 剛剛成功領(lǐng)取
        梁同學 157****2950 剛剛成功領(lǐng)取
        劉同學 189****1015 剛剛成功領(lǐng)取
        張同學 155****4678 剛剛成功領(lǐng)取
        鄒同學 139****2907 剛剛成功領(lǐng)取
        董同學 138****2867 剛剛成功領(lǐng)取
        周同學 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        云原生存儲和云存儲有什么區(qū)別?

        一、架構(gòu)設(shè)計不同云原生存儲是指在云原生環(huán)境下設(shè)計和構(gòu)建的存儲系統(tǒng)。它是基于云原生計算模式和原則進行設(shè)計,充分利用容器、微服務(wù)和自動化管...詳情>>

        2023-10-14 06:50:34
        如何刪除需要使用管理員權(quán)限才能刪除的文件?

        如何刪除需要使用管理員權(quán)限才能刪除的文件在Windows系統(tǒng)中,有時候我們可能會遇到一些需要管理員權(quán)限才能刪除的文件。這是因為這些文件可能是...詳情>>

        2023-10-14 06:27:57
        有什么好用的redis可視化管理工具?

        一、Redis Desk較好 ManagerRedis Desk較好 Manager是一款非常受歡迎的Redis數(shù)據(jù)庫管理工具。它支持直接進行數(shù)據(jù)修改、刪除和新增等操作,而且...詳情>>

        2023-10-14 06:24:43
        市場上C++主要是用來做什么的?

        C++是一種廣泛應(yīng)用于市場上的編程語言,具有高性能和強大的功能。它的設(shè)計目標是提供高效的底層控制和與硬件交互的能力,同時保持可移植性和可...詳情>>

        2023-10-14 06:01:51
        為什么說PHP與Swoole是優(yōu)異組合?

        PHP與Swoole在Web開發(fā)和網(wǎng)絡(luò)編程領(lǐng)域中,共同構(gòu)成了一種強大的解決方案。什么是PHPPHP是一種廣泛使用的開源服務(wù)器端腳本語言,特別適用于Web開...詳情>>

        2023-10-14 05:08:41
        上思县| 长沙市| 微山县| 黔南| 息烽县| 习水县| 明星| 华安县| 新沂市| 襄汾县| 沁阳市| 曲沃县| 英德市| 开封县| 土默特左旗| 会理县| 北海市| 淮北市| 平舆县| 宿松县| 黄山市| 万州区| 平顺县| 马边| 乾安县| 陵水| 辽中县| 荥阳市| 临邑县| 达拉特旗| 仲巴县| 静安区| 尖扎县| 二连浩特市| 囊谦县| 张家川| 大荔县| 桐乡市| 延吉市| 呼玛县| 巫山县|