中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java數組怎么插入元素并快捷排序

發布時間:2021-04-28 10:18:44 來源:億速云 閱讀:144 作者:小新 欄目:編程語言

小編給大家分享一下java數組怎么插入元素并快捷排序,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Java的特點有哪些

Java的特點有哪些 1.Java語言作為靜態面向對象編程語言的代表,實現了面向對象理論,允許程序員以優雅的思維方式進行復雜的編程。 2.Java具有簡單性、面向對象、分布式、安全性、平臺獨立與可移植性、動態性等特點。 3.使用Java可以編寫桌面應用程序、Web應用程序、分布式系統和嵌入式系統應用程序等。

本教程操作環境:windows7系統、java10版,DELL G3電腦。

1、從數組的第二個元素進行操作,如果發現其前面的元素比他大,就將其前面的元素往后挪,直到cur指向的元素大于或者等于他前一個元素,此時cur指向的位置就是待插入元素應該插入的位置。

static int[] insertSort2(int[] array){
 
    int len = array.length;
 
    for (int begin = 1; begin < len; begin++){
 
        int cur = begin;
 
        int tmp = array[cur];
 
        while (cur > 0 && array[cur] < array[cur-1]){
 
            array[cur] = array[cur-1];
 
            cur--;
 
        }
 
        array[cur] = tmp;
 
    }
 
    return array;
 
}

2、通過二分查找減少了比較次數,即cmp函數的調用,還減少了swap函數的調用。更快的找到了當前元素應該插入的位置,然后再進行挪動,提高了效率。

static int[] insertSort3(int[] array){
 
        int len = array.length;
 
 
 
        for (int begin = 1; begin < len; begin++){
 
            int v = array[begin];
 
            int insertIndex = search(array,begin);
 
            // 將 [insertIndex, begin) 范圍內的元素往右邊挪動一個單位
 
            for (int i = begin; i > insertIndex; i--){
 
                array[i] = array[i-1];
 
            }
 
            array[insertIndex] = v;
 
        }
 
        return array;
 
    }
 
    static int search(int[] array, int index){
 
        int begin = 0;
 
        int end = index;
 
        while(begin < end){
 
            int mid = (begin+end) >> 1;
 
            if (array[index] < array[mid]){
 
                end = mid;
 
            }else{
 
                begin = mid+1;
 
            }
 
        }
 
        return begin;
 
}

需要注意的是:使用了二分搜索后,只是減少了比較次數,但插入排序的平均時間復雜度依然是O(n^2)。

以上是“java數組怎么插入元素并快捷排序”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節
推薦閱讀:
  1. java數組排序
  2. 插入排序

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

莱阳市| 册亨县| 红安县| 南投县| 台安县| 南昌市| 福清市| 密山市| 河西区| 嘉义县| 巫溪县| 利辛县| 新和县| 武定县| 双鸭山市| 清远市| 墨竹工卡县| 邓州市| 永仁县| 巨鹿县| 盱眙县| 罗田县| 万山特区| 布拖县| 连平县| 巨野县| 崇义县| 清流县| 睢宁县| 靖州| 丹巴县| 德阳市| 东明县| 固阳县| 墨玉县| 黄冈市| 丹东市| 荔浦县| 高淳县| 澄城县| 巴彦县|