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

704.二分查找

链接:704.二分查找

class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0;
        int right = nums.size() - 1;
        int mid = 0;

        while(left <= right)
        {
            mid = (left + right) / 2;
            if(nums[mid] == target) return mid;
            else if(nums[mid] > target) 
                right = mid - 1;
            else
                left = mid + 1;
        }

        return -1;
    }
};

参考资料

1.链接:代码随想录算法公开课-704.二分查找

思路与收获

1.因为之前写过二分查找,所以一气呵成写出来,顺利提交;
2.看了代码随想录算法公开课的讲解视频,熟悉了搜索区间分别为左闭右闭和左闭右开两种情况下的写法,我的代码中设置搜索区间为左闭右闭。

27.移除元素

链接:27.移除元素

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        if(nums.size() == 0) return 0;
        
        int* p1 = &nums[0];
        int* p2 = &nums[0];
        
        while(p2 <= &nums[0] + nums.size() - 1)
        {
            if(*p1 == val && *p2 == val)
            {
                p2++;
            }
            else if(*p1 == val && *p2 != val)
            {
                *p1 = *p2;
                *p2 = val;
                p1++;
                p2++;
            }
            else if(*p1 != val && *p2 != val)
            {
                p1++;
                p2++;
            }
        }
        
        return p1 - &nums[0];
    }
};

参考资料

1.力扣官方题解

思路与收获

1.想了很长时间,不过最后还是写出了双指针方案的代码,一次提交通过,完成之前觉得自己的算法已经很好了,完成之后看了力扣的官方题解,觉得还是有一些冗余的操作,与官方题解未优化的双指针方案差不多,不够完美。代码的时间复杂度为O(n)。
2.官方题解优化后的双指针方案左指针与右指针移动的次数加起来等于数组的长度,我的代码中p2指针移动的次数和p1指针移动的次数大于数组的长度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值