代码随想录算法训练营第一天 |LeetCode 704. 二分查找 27. 移除元素

 704. 二分查找 

题目链接:. - 力扣(LeetCode)

看到题目的第一想法:奇偶要分开思考;while循环,跳出条件为找出值或是没有找到(-1or>数组长度);判断语句为与target比大小

看完代码随想录之后的想法 :用双指针做滑动窗口;注意指针与mid的关系,不小心就会一直while;区间不变量

class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left=0,right=nums.size()-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]==target){
                return mid;
            }else if(nums[mid]>target){
                right=mid-1;
            }else{
                left=mid+1;
            }
        }
        return -1;
    }
    
};
 27. 移除元素

题目链接:. - 力扣(LeetCode)

看到题目的第一想法:利用指针做循环遍历;用erase

看完代码随想录之后的想法 :双指针,快慢指针,一个遍历查找,一个记录需要删除的数的标;逆向思维(我想的是if用==val,而这个选择了对!=的进行更新操作)

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int slowIndex = 0;
        for (int fastIndex = 0; fastIndex < nums.size(); fastIndex++) {
            if (val != nums[fastIndex]) {
                nums[slowIndex++] = nums[fastIndex];
            }
        }
        return slowIndex;
    }
};

学习时长:3h

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值