代码随想录笔记--数组篇

1--二分查找法

二分查找法用于有序数组的元素查找,一般可以分为左闭右闭 写法、左闭右开 写法、左开右闭写法,其中左闭右闭写法最常用;

cpp 复制代码
#include <iostream>
#include <vector>

class Solution {
public:
    // 左闭右闭写法
    int search1(std::vector<int>& arr, int target){
        int left = 0, right = arr.size() - 1;
        while(left <= right){ // 因为是左闭右闭写法,当left == right时[left, right]也是合法的,因此left <= right
            int mid = left + (right - left) / 2;
            if(arr[mid] > target){
                right = mid - 1;
            }
            else if(arr[mid] < target){
                left = mid + 1;
            }
            else return arr[mid];
        }
        return -1; // 表示未找到
    }

    // 左闭右开写法
    int search2(std::vector<int>& arr, int target){
        int left = 0, right = arr.size();
        while(left < right){ // 因为是左闭右开写法,当left == right时[left, right)是非法的,因此left < right
            int mid = left + (right - left) / 2;
            if(arr[mid] > target){
                right = mid; // 右开
            }
            else if(arr[mid] < target){
                left = mid + 1; // 左闭
            }
            else return arr[mid];
        }
        return -1; // 表示未找到
    }

    // 左开右闭写法
    int search3(std::vector<int>& arr, int target){
        int left = -1, right = arr.size() - 1;
        while(left < right){ // 因为是左闭右开写法,当left == right时(left, right]是非法的,因此left < right
            int mid = left + (right - left) / 2;
            if(arr[mid] > target){
                right = mid - 1; // 右闭
            }
            else if(arr[mid] < target){
                left = mid; // 左开
            }
            else return arr[mid];
        }
        return -1; // 表示未找到
    }
};

int main(int argc, char *argv[]){
    std::vector<int> test = {1, 2, 3, 4, 5, 6, 7, 8, 9};
    int target = 2;
    Solution S1;
    int res1 = S1.search1(test, target);
    int res2 = S1.search2(test, target);
    int res3 = S1.search3(test, target);
    std::cout << res1 << ", " << res2 << ", " << res3 << std::endl;
    return 0;
}

2--二分查找法进阶

2-1--寻找第一个等于目标值的位置

等于号 = 放在哪个条件判断的依据:当 arr[mid] == target 时,应该往哪一边继续二分寻找;

cpp 复制代码
#include <iostream>
#include <vector>

class Solution {
public:
    // 左闭右闭写法
    int search1(std::vector<int>& arr, int target){
        int left = 0, right = arr.size() - 1;
        int res = -1;
        while(left <= right){
            int mid = left + (right - left) / 2;
            if(arr[mid] >= target){
                res = mid; // 记录可能的位置
                right = mid - 1;
            }
            else if(arr[mid] < target){
                left = mid + 1;
            }
        }
        if(res == -1 || arr[res] != target) return -1; //未找到target
        return res;
    }

};

int main(int argc, char *argv[]){
    std::vector<int> test = {1, 2, 2, 2, 3, 3, 4};
    int target = 2;
    Solution S1;
    int res1 = S1.search1(test, target);
    std::cout << res1 << std::endl;
    return 0;
}

2-2--寻找最后一个等于目标值的位置

等于号 = 放在哪个条件判断的依据:当 arr[mid] == target 时,应该往哪一边继续二分寻找;

cpp 复制代码
#include <iostream>
#include <vector>

class Solution {
public:
    // 左闭右闭写法
    int search1(std::vector<int>& arr, int target){
        int left = 0, right = arr.size() - 1;
        int res = -1;
        while(left <= right){
            int mid = left + (right - left) / 2;
            if(arr[mid] > target){
                right = mid - 1;
            }
            else if(arr[mid] <= target){
                res = mid; // 记录可能的位置
                left = mid + 1;
            }
        }
        if(res == -1 || arr[res] != target) return -1; //未找到target
        return res;
    }

};

int main(int argc, char *argv[]){
    std::vector<int> test = {1, 2, 2, 2, 3, 3, 4};
    int target = 2;
    Solution S1;
    int res1 = S1.search1(test, target);
    std::cout << res1 << std::endl;
    return 0;
}
相关推荐
平行侠22 分钟前
022Miller-Rabin 概率素性检验 - 概率与数论的完美联姻
数据结构·算法
wuweijianlove36 分钟前
算法与数据结构协同优化的设计思想的技术7
数据结构·算法
故事和你9141 分钟前
洛谷-数据结构2-1-二叉堆与树状数组1
开发语言·数据结构·c++·算法·动态规划·图论
多加点辣也没关系1 小时前
数据结构与算法|第十七章:贪心算法
数据结构·算法·贪心算法
多加点辣也没关系1 小时前
数据结构与算法|第十四章:排序算法(上)— 比较类排序
数据结构·算法·排序算法
北顾笙9802 小时前
day42-数据结构力扣
数据结构
风筝在晴天搁浅2 小时前
阿里淘天/京东 CodeTop LeetCode103.二叉树的锯齿形层序遍历
数据结构
郝学胜-神的一滴2 小时前
干货版《算法导论》03:动态数组 × 链表的极致平衡艺术
java·数据结构·c++·python·算法·链表
图码3 小时前
最大子数组和问题:从暴力到Kadane算法的优雅蜕变
数据结构·算法·动态规划·柔性数组
庞轩px3 小时前
第一篇:Redis数据结构底层——String、List、Hash、Set、ZSet各自用什么实现的?
数据结构·redis·list·set·hash·string·zset