补卡!!算法训练营Day01

一、数组的相关概念

  数组指的是存放在一片连续内存空间且相同数据类型的数据的集合。

  数组的特点:

    数组处于的内存空间的地址是连续的

    数组的下标是从0开始

    数组的元素只能覆盖,无法删除

二、刷题

 704.二分查找

题目链接:704. 二分查找 - 力扣(LeetCode)

双闭区间:

class Solution {
public:
    int search(vector<int>& nums, int target) {
    // 初始化双闭区间 [0, n-1] ,即 i, j 分别指向数组首元素、尾元素
    int i = 0, j = nums.size() - 1;
    // 循环,当搜索区间为空时跳出(当 i > j 时为空)
    while (i <= j) {
        int m = i + (j - i) / 2; // 计算中点索引 m
        if (nums[m] < target)    // 此情况说明 target 在区间 [m+1, j] 中
            i = m + 1;
        else if (nums[m] > target) // 此情况说明 target 在区间 [i, m-1] 中
            j = m - 1;
        else // 找到目标元素,返回其索引
            return m;
    }
    // 未找到目标元素,返回 -1
    return -1;

    }
};

左闭右开:

class Solution {
public:
    int search(vector<int>& nums, int target) {
    // 初始化左闭右开区间 [0, n) ,即 i, j 分别指向数组首元素、尾元素
    int i = 0, j = nums.size();
    // 循环,当搜索区间为空时跳出(当 i >= j 时为空)
    while (i < j) {
        int m = i + (j - i) / 2; // 计算中点索引 m
        if (nums[m] < target)    // 此情况说明 target 在区间 [m+1, j) 中
            i = m + 1;
        else if (nums[m] > target) // 此情况说明 target 在区间 [i, m) 中
            j = m;
        else // 找到目标元素,返回其索引
            return m;
    }
    // 未找到目标元素,返回 -1
    return -1;

    }
};

注解(来源于:hello算法-二分查找):

  如图所示,在两种区间表示下,二分查找算法的初始化、循环条件和缩小区间操作皆有所不同。

  由于“双闭区间”表示中的左右边界都被定义为闭区间,因此通过指针 𝑖 和指针 𝑗 缩小区间的操作也是对称的。这样更不容易出错,因此一般建议采用“双闭区间”的写法

27.移除元素

题目链接:27. 移除元素 - 力扣(LeetCode)

暴力:

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int k=nums.size();
        for(int i=0;i<nums.size();i++){
            if(nums[i]==val){
                nums[i]=101;
                k--;
                }
        }
        sort(nums.begin(),nums.end());
        return k;

    }
};

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值