二分查找和删除元素【双指针】

发布时间:2024年01月11日
class Solution {
public:
    int search(vector<int>& nums, int target) {
    
      int left=0;
      int right=nums.size()-1;
      while(left<=right)
      {
         int mid=(left+right)/2;
         if(target>nums[mid])
              left=mid+1;
           else if(target<nums[mid])
               right=mid-1;
           else
           {
               return mid;
           }
      }
      return -1;
    }
};
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
    int left=0;
    int right=0;
    for(;left<nums.size();left++)
    {
        if(nums[left]!=val)
        {
            nums[right++]=nums[left];
        }
         
    }
return right;    
    }
};

文章来源:https://blog.csdn.net/weixin_62518305/article/details/135534164
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。