C++二分查找

1.算法

1.1 什么是算法

算法是一种解决问题的方法,它并不是一个新的知识点,而是讲我们学习过的知识点运用起来解决问题。

1.2 算法的时间复杂度

时间复杂度指的是算法所要执行的次数,而不是时间,我们学习的每个算法都会告知时间复杂度,但是目前我们先不学习如何计算算法的时间复杂度,以后再说。

2.二分查找

2.1 704. 二分查找 - 力扣(LeetCode)

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

2.2 什么是二分查找

二分查找 是一种高效的、方便的、简单的查找数据的方式,二分查找一般 运用与有序序列中,这样才能进行二分查找。

2.3 二分查找的原理

我们先定义两个指针,分别指向数组的第一个和最后一个数的下标,我们在算出这两个指针之间的中间下标,定义为变量mid,如果mid的值比要查找的数大,那么就把右指针移动到mid-1的位置,如果小,就把左指针移动到mid+1的位置,如果相等,那么输出mid。

2.4 二分查找的模板

cpp 复制代码
while(left < right)
{
    int mid = (left + right) / 2;
    if(arr[mid] > target)
        right = mid - 1;
    else if(arr[mid] < target)
        left = mid + 1;
    else
    {
        cout << mid << endl;
        break;
    }
}

注:二分查找的时间复杂度为O(Logn)

2.5 参考答案

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0, right = nums.size() - 1;
        while(left <= right)
        {
            int mid = (left + right) / 2;
            if(nums[mid] == target)
                return mid;
            else if(nums[mid] > target)
                right = mid - 1;
            else
                left = mid + 1;
        }
        return -1;
    }
};

再见!

相关推荐
天若有情6739 分钟前
程序员原创|借鉴JS事件冒泡,根治电脑文件混乱的“冒泡整理法”
开发语言·javascript·windows·ecmascript·电脑·办公·日常
一切皆是因缘际会10 分钟前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
墨染千千秋11 分钟前
C++函数的使用以及主函数
c++
Java成神之路-12 分钟前
【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解
算法·leetcode
不忘不弃16 分钟前
用BFS方法求解平分汽油问题
算法·宽度优先
AI科技星28 分钟前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
风落无尘36 分钟前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
JAVA面经实录91742 分钟前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
特种加菲猫1 小时前
继承,一场跨越时空的对话
开发语言·c++
AC赳赳老秦1 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw