栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

二分查找——面试必刷TOP101

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

二分查找——面试必刷TOP101

二分查找

BM17 二分查找-I

import java.util.*;

public class Solution {

    public int search (int[] nums, int target) {
        int i=0,j=nums.length-1;
        while(i<=j){
            int m=(i+j)/2;
            if(nums[m]==target) return m;
            else if(nums[m]>target) j=m-1;
            else i=m+1;
        }
        return -1;
    }
}

BM19 寻找峰值

import java.util.*;

public class Solution {

    public int findPeakElement (int[] nums) {
        int i=0,j=nums.length-1;
        while(i
            int m=(i+j)/2;
            if(nums[m]>nums[m+1]) j=m;
            else i=m+1;
        }
        return j;
    }
}

BM21 旋转数组的最小数字

import java.util.ArrayList;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        int i=0,j=array.length-1;
        while(i
            int m=i+(j-i)/2;
            if(array[m]>array[j]) i=m+1;
            else if(array[m] 

34.在排序数组中查找元素的第一个和最后一个位置

class Solution {
    public int[] searchRange(int[] nums, int target) {
        if(nums.length == 0) return new int[]{-1,-1};    
        int l = 0, r = nums.length - 1; 
        while( l < r){//查找元素的左位置
            int m = (l + r)/2;
            if(nums[m] >= target) r = m;
            else l = m + 1;
        }
        if( nums[r] != target) return new int[]{-1,-1}; //查找失败
        int L = r;
        l = 0; r = nums.length - 1;    
        while( l < r){//查找元素的右位置
            int m = (l + r + 1)/2;//+1是为了防止死循环
            if(nums[m] <= target ) l = m;
            else  r = m-1;
        }
        return new int[]{L,r};
    }
}

BM18 二维数组中的查找

public class Solution {
    public boolean Find(int target, int [][] arr) {
        int i=arr.length-1,j=0;
        while(i>=0 &&j
            if(arr[i][j]==target) return true;
            else if(arr[i][j]>target) i--;
            else j++;
        }
        return false;
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/860173.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号