数据结构算法学习day3——二分查找

一.算法描述

二.算法实现

java 复制代码
package com.algorithm.binarysearch;

public class BinarySearch {
    /*params:a - 待查找的升序数组
             target - 待查找的目标值
      Returns:
            找到则返回索引
            找不到则返回-1
    * */
    public static int binarySearch(int[] a,int target){//设置元素个数数组和待查找的目标值
        int i = 0,j = a.length - 1;//设置指针和初值
        while(i<=j){
            int m = (i+j) >>> 1; //用无符号右移运算符,防止溢出
            if(target < a[m]){//目标值在中间值左边的情况下
                j = m - 1;
            }else if(target >a[m]){//目标值在中间值右边的情况下
                i = m + 1;
            }else {
                return m; //找到中间值
            }
        }
        return -1;//找不到的情况下返回-1
    }
}
java 复制代码
package com.algorithm.binarysearch;

public class BinarySearch {
    /*params:a - 待查找的升序数组
             target - 待查找的目标值
      Returns:
            找到则返回索引
            找不到则返回-1
    * */
    public static int binarySearch(int[] a,int target){//设置元素个数数组和待查找的目标值
        int i = 0,j = a.length;//设置指针和初值
        while(i<j){
            int m = (i+j) >>> 1; //用无符号右移运算符,防止溢出
            if(target < a[m]){//目标值在中间值左边的情况下
                j = m;
            }else if(target >a[m]){//目标值在中间值右边的情况下
                i = m + 1;
            }else {
                return m; //找到中间值
            }
        }
        return -1;//找不到的情况下返回-1
    }
}

三.查找问题

问题一

**q:**为什么是i<=j意味着区间内有未比较元素,而不是i<j?

**s:**i,j 它们指向的元素也会参与比较。

问题二

q:(i+j)/2有没有问题?

**s:**同一个二进制数,在java中会把第一位看作符号位,所以用">>>"无符号右移运算符,防止溢出。

问题三

**q:**在比较中写成"<"小于符号有何好处?

**s:**数组是升序排列的,写成小于符号可以是和数组升序排列方向一致,不然会很别扭。

四.如何判断算法好坏

1.时间复杂度

含义:是用来衡量一个算法的执行,随数据规模增大,而增长的时间成本。

2.如何表示时间复杂度

假设算法要处理的数据规模是n,代码总的执行行数用函数f(n)来表示,例如:

  • 线性查找算法的函数f(n) = 3*n+3
  • 二分查找算法的函数f(n) = (floor(log2(n)+1)*5+4

渐进上界:代表算法执行的最差情况

渐进下界:代表算法执行的最好情况

渐进紧界:既能代表算法执行的最好情况,也能代表算法执行的最差情况

3.常见的大O表示法

4.空间复杂度

与时间复杂度类似,一般也是用大O表示法来衡量:一个算法执行随数据规模增大,而增长的额外空间成本。

5.二分查找性能

五.插入数组

将数组中没有的元素插入进去

六.寻找最侧边元素

1.寻找最左侧元素

java 复制代码
package com.algorithm.binarysearch;

public class BinarySearch {
    /*params:a - 待查找的升序数组
             target - 待查找的目标值
      Returns:
            找到则返回索引
            找不到则返回-1
    * */
    public static int binarySearch(int[] a,int target){
        int i = 0,j = a.length - 1;
        int candidate = -1//表示没有任何候选者
        while(i<=j){
            int m = (i+j) >>> 1; 
            if(target < a[m]){
                j = m - 1;
            }else if(target >a[m]){
                i = m + 1;
            }else {
                //记录侯选位置
                condidate = m;
                j = m - 1;
            }
        }
        return -1;
}

2.寻找最右侧元素

java 复制代码
package com.algorithm.binarysearch;

public class BinarySearch {
    /*params:a - 待查找的升序数组
             target - 待查找的目标值
      Returns:
            找到则返回索引
            找不到则返回-1
    * */
    public static int binarySearch(int[] a,int target){
        int i = 0,j = a.length - 1;
        int candidate = -1//表示没有任何候选者
        while(i<=j){
            int m = (i+j) >>> 1; 
            if(target < a[m]){
                j = m - 1;
            }else if(target >a[m]){
                i = m + 1;
            }else {
                //记录侯选位置
                condidate = m;
                i = m + 1;
            }
        }
        return condidate;
}
相关推荐
_OP_CHEN36 分钟前
【算法基础篇】(五十七)线性代数之矩阵乘法从入门到实战:手撕模板 + 真题详解
线性代数·算法·矩阵·蓝桥杯·c/c++·矩阵乘法·acm/icpc
天天爱吃肉821841 分钟前
【跨界封神|周杰伦×王传福(陶晶莹主持):音乐创作与新能源NVH测试,底层逻辑竟完全同源!(新人必看入行指南)】
python·嵌入式硬件·算法·汽车
im_AMBER42 分钟前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
EmbedLinX44 分钟前
嵌入式之协议解析
linux·网络·c++·笔记·学习
楚轩努力变强1 小时前
iOS 自动化环境配置指南 (Appium + WebDriverAgent)
javascript·学习·macos·ios·appium·自动化
考琪1 小时前
Nginx打印变量到log方法
java·运维·nginx
盐焗西兰花1 小时前
鸿蒙学习实战之路-Reader Kit自定义页面背景最佳实践
学习·华为·harmonyos
薛定谔的猫喵喵1 小时前
基于PyQt5的视频答题竞赛系统设计与实现
开发语言·qt·音视频
岱宗夫up1 小时前
Python 数据分析入门
开发语言·python·数据分析
xhbaitxl1 小时前
算法学习day38-动态规划
学习·算法·动态规划