算法题每日一练---第78天:二分查找

简介: 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target

4.png


一、问题描述

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target  ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1


题目链接:二分查找


二、题目要求


样例 1

输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4


样例 2

输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1


考察

二分查找
建议用时10~25min


三、问题分析


这一题是二分查找实际应用了,对于二分查找来说,其实就是不断向中间逼近的一个过程,查找的序列必须是有序的,乱序的话可没有办法进行二分查找哦。

15.png

如上图,二分查找一般分成下面5个步骤:

  • 设定左右指针,l=0,r=n-1
  • 找出中间位置,mid=l+(r-l)/2 (这样写防止溢出)
  • nums[mid] == target 则返回该位置下标
  • nums[mid] > target 则右侧指针移到中间
  • nums[mid] < target 则左侧指针移到中间


四、编码实现


classSolution {
public:
intsearch(vector<int>&nums, inttarget) {
intl,r,n=nums.size(),mid;//设定左右指针l=0,r=n-1;
while(l<=r)
        {
mid=l+(r-l)/2;//找出中间位置if(nums[mid]==target)//成功找到,返回该位置下标returnmid;
if(nums[mid]>target)//右侧指针移到中间r=mid-1;
if(nums[mid]<target)//左侧指针移到中间l=mid+1;
        }
return-1;
    }
};

五、测试结果16.png

相关文章
|
3月前
|
算法 测试技术 索引
算法-二分查找
算法-二分查找
32 0
|
6天前
|
算法
【算法】二分查找——二分查找
【算法】二分查找——二分查找
|
6天前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
4天前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
1月前
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
25 0
【算法】二分查找(整数二分和浮点数二分)
|
2月前
|
存储 算法 C语言
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
|
2月前
|
机器学习/深度学习 算法 索引
数据结构算法--1 顺序查找二分查找
**顺序查找时间复杂度为O(n)**,适合无序列表,可以通过`enumerate`或直接遍历索引来实现。**二分查找时间复杂度为O(logn)**,适用于有序列表,利用Python中`left`、`right`指针和`mid`点不断缩小搜索范围。效率上二分查找更优。
|
2月前
|
存储 算法 Java
Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。
【6月更文挑战第21天】Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。简单哈希表实现未涵盖冲突解决和删除操作。
28 1
|
2月前
|
算法 搜索推荐 Java
二分查找算法详解及实现
二分查找算法详解及实现
36 2
|
1月前
|
算法 JavaScript
JS 【算法】二分查找
JS 【算法】二分查找
20 0

热门文章

最新文章