您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息

java数组插入元素并快捷排序的方法

2024/4/20 12:33:28发布5次查看
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; }
以上就是java数组插入元素并快捷排序的方法的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录