二分法基本思路和实现

本文介绍了二分法在有序数组中的应用,包括查找特定数值、寻找大于等于目标的最左侧位置、查找元素的第一个和最后一个位置,以及解决局部最大值问题。通过具体的LeetCode题目示例,详细解释了每种情况的二分查找思路和代码实现,帮助读者深入理解二分法的运用。
摘要由CSDN通过智能技术生成

🚀 优质资源分享 🚀

学习路线指引(点击解锁) 知识定位 人群定位
🧡 Python实战微信订餐小程序 🧡 进阶级 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛 入门级 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

二分法基本思路和实现

作者:Grey

原文地址:

博客园:二分法基本思路和实现

CSDN: 二分法基本思路和实现

在一个有序数组中,找某个数是否存在

OJ 见:LeetCode 704. Binary Search

思路:

  1. 由于是有序数组,可以先得到中点位置,中点可以把数组分为左右半边。
  2. 如果中点位置的值等于目标值,直接返回中点位置。
  3. 如果中点位置的值小于目标值,则去数组中点左侧按同样的方式寻找。
  4. 如果中点位置的值大于目标值,则取数组中点右侧按同样的方式寻找。
  5. 如果最后没有找到,则返回:-1。

代码

class Solution {
    public int search(int[] arr, int t) {
        if (arr == null || arr.length < 1) {
            return -1;
        }
        int l = 0;
        int r = arr.length - 1;
        while (l <= r) {
            int m = l + ((r - l) >> 1);
            if (arr[m] == t) {
                return m;
            } else if (arr[m] > t) {
                r = m - 1;
     
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值