数据查找算法总结1

来源:互联网 发布:女生湿 知乎 编辑:程序博客网 时间:2024/06/04 20:13

1.二分法查找

介绍:前提是当前要查询的数组的有顺序的。根据值得对比,逐步成半的缩小范围。

public int binarySearch(long[]arr,long value) {    int min = 0;    int max = elements;    int mid = 0;    while (true) {        mid = (min + max) / 2;        if(arr[mid] > value){            // 左移            max = mid;        }else if(arr[mid] < value){             // 右移            min = mid;        }else{            return mid;        }        if(min > max){  // 到头了            return -1;        }    }}

2. 冒泡排序

这里写图片描述


介绍:从第一位开始以此确定每个位置上的正确数,
最坏的情况下时间复杂度为 n * (n - 1) / 2,即 O(n^2):

/** * 冒泡排序(由小到大) */public static void bubbleSort(long[] arr) {    long temp = 0;    for (int i = 0; i < arr.length - 1; i++) {        for (int j = i+ 1; j <arr.length ; j++) {            if (arr[j] < arr[i]) {                temp = arr[j];                arr[j] = arr[i];                arr[i] = temp;            }        }    }}

3.插入排序


原理:假设第一个元素被放到了正确的位置上,假设第二个、第三个、第四个。。。。

这里写图片描述

/**  * 插入排序,  * @param arr  */ public static void sort(int [] arr){     int temp = 0 ;     for(int i = 1;i <arr.length; i++ ){         temp = arr[i];         int j = i;         while(j> 0 && temp > arr[j - 1] ){             arr[j] = arr[j - 1];             j--;         }         arr[j] = temp;     } }

4. 希尔排序

原理: 在插入排序的基础上增大间隔。假设前h 个是对的。
h的计算方式为:
int h = 1;
while(h > arr.length/3){
h = h* 3 +1;
}


图解:
这里写图片描述


/** * 希尔排序 * @param arr */public static void sortByxier (int [] arr){    int h = 1;    while(h >  arr.length /3){        h = h * 3 + 1;    }    /*控制h , h> 0 */    while(h>  0 ){        int temp = 0;        for(int i = h;i < arr.length;i ++ ){            temp = arr[i];            int j = i;            while(j> h-1 && temp < arr[j - h ]){                arr[j] = arr[j- h];                j = j-h ;            }            arr[j] = temp;        }        h = (h-1)/3;    }}
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 淘宝盗用图片被投诉怎么办 淘宝别人盗用我的图片怎么办 淘宝盗图申诉原图过大怎么办 淘宝别人举报我盗用图片怎么办 淘宝卖家被投诉盗图怎么办 淘宝卖家被投诉卖假货怎么办 淘宝买到假货卖家不承认怎么办 被投诉盗图扣2分怎么办 拼多多盗淘宝图怎么办 微信视频清理了怎么办 牛仔短裤买大了怎么办 淘宝图片打开变大了怎么办 同城换公司社保怎么办 劳务不给交社保怎么办 好多工厂外包工不交社保怎么办 外包公司没有交社保怎么办 外包公司不给交社保怎么办 银行取100万现金怎么办 给老外发警告信后怎么办 照片上传是歪的怎么办 日亚不能直邮的怎么办 电话信息被卖了怎么办 被亚马逊跟卖了怎么办 玉米出芽后土壤不够湿怎么办 雨伞请输入授权码怎么办 网页放手机端后看不了怎么办 微信收款码存在违法行为怎么办 tst优惠码密码忘了怎么办 扩展器登录不上怎么办 微信学法小程序积分不更新怎么办 开发商不给办房产证怎么办 传淘宝产品规格不匹配怎么办 刚买的手机想退怎么办 空调主机空间不足不散热怎么办 lol网速快延迟高怎么办 4g手机延迟高怎么办 天气冷鼻炎就犯怎么办 天气冷宝宝发烧了怎么办 wp手机开机忘记了密码怎么办 微商退货不退款怎么办 微商退货了不退款怎么办