代码随想录第一天|704.二分查找 27.移除元素

写法一:左右区间可以相等,left = right(左右区间的值都可以取到,这是更新left和right的依据)

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

写法二:左右区间不能相等,即为left<right

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0;
        int right = nums.size();//因为right的边界值是不可取的,所有不要减一
        while(left<right){
            int middle = left + (right - left)/2;
            if(nums[middle]>target){
                right = middle;//此时middle为不可取的边界值,故middle因从为middle开始
            }
            else if(nums[middle]<target)
            {
                left = middle + 1; 
            }
            else{
                return middle;
            }
        }
        return -1;
    }
};

27.移除元素

写法一:暴力解法

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int size = nums.size();
        for(int i = 0;i<size;i++){//找到目标值
            if(nums[i]==val){
                for(int j = i + 1;j<size;j++){//将数组往前移动一位
                        nums[j-1] = nums[j];
                }
                i--;//因为此时还未检查的数组值,已经替代了目标值的位置了,但不能跳过它
                    //因为它可能也是目标值
                size--;
            }
        }
        return size;
    }
};

写法二:双指针法,快慢指针

注释:快慢指针,实质上是一个数组的自我复制,只不过里面有一些数据是不合格的,所有需要进行删除更新,而这时候,快慢指针的两者不同的作用就展示出来了,数组整体被分割为俩个部分

一为下标,二为数据,下标由slowIndex控制,数据由fastIndex控制,二者俩结合就形成了一个符合题意的新数组

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int slowIndex = 0;
        int size = nums.size();
        for(int fastIndex = 0;fastIndex<size;fastIndex++){
            if(nums[fastIndex]!=val){
                nums[slowIndex++] = nums[fastIndex];
            }
        }
        return slowIndex;
    }
};
相关推荐
Paddi9301 小时前
Codeforces Round 1004 (Div. 1) C. Bitwise Slides
c++·算法
Luis Li 的猫猫2 小时前
深度学习中的知识蒸馏
人工智能·经验分享·深度学习·学习·算法
查理零世2 小时前
【蓝桥杯集训·每日一题2025】 AcWing 6118. 蛋糕游戏 python
python·算法·蓝桥杯
敲代码的小王!2 小时前
MD5加密算法和BCrypt密码加密算法
java·算法·安全
带娃的IT创业者3 小时前
机器学习实战(6):支持向量机(SVM)——强大的非线性分类器
算法·机器学习·支持向量机
Java能学吗5 小时前
2.17学习总结
数据结构·学习
孑么5 小时前
力扣 买卖股票的最佳时机
算法·leetcode·职场和发展·贪心算法·动态规划
诚信爱国敬业友善6 小时前
常见排序方法的总结归类
开发语言·python·算法
gentle_ice7 小时前
跳跃游戏 II - 贪心算法解法
数据结构·算法·leetcode·贪心算法
不只会拍照的程序猿8 小时前
从插入排序到希尔排序
java·开发语言·数据结构·算法·排序算法