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

数组理论基础:

C++中,数组内存空间的地址连续,二维数组也同理;
不能单独删除某一数组元素,只能通过覆盖的方式。

704.二分查找

int right = nums.size() -1 ; (若为左闭右开区间则不需要-1:原因是右开区间无法取到,再-1可能会丢失元素?)

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(nums[mid] > target){
         right = mid - 1;   
    }else if(nums[mid] < target){
        left = mid + 1;
    }else return mid;
    }return -1 ;
    }
};

27.移除元素

1. 暴力解法

采用两层for循环,一层遍历数组,一层更新新的数组。(注意数组越界问题)

//暴力解法
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int size = nums.size() ;
     for(int i = 0;  i <nums.size(); i++){
         if(nums[i] == val){
             for(int j =i+1 ; j< nums.size(); j++){
             nums[j-1] = nums[j] ;   
         }
         i--;
         size --;
     }
    }return size;
    }
};

2.双指针法

//双指针解法
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
      int slow = 0;
      for(int fast = 0; fast <nums.size(); fast++){
          if(nums[fast] != val){
          nums[slow] = nums[fast];
          slow ++;}
      }return slow;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值