当前位置: 首页 > article >正文

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

704.

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

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

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.移除元素

写法一:暴力解法

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控制,二者俩结合就形成了一个符合题意的新数组

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;
    }
};


http://www.kler.cn/news/359031.html

相关文章:

  • 【论文精读】把一切转成mesh!MeshAnything和MeshAnythingV2论文解析
  • 使用centos8在docker环境下编译ceph reef并使用s3cmd与awscli测试
  • 【某农业大学计算机网络实验报告】实验五 TCP 运输连接管理
  • RFC2616 超文本传输协议 HTTP/1.1
  • 修改pq_default.ini禁用降噪,解决S905X3电视盒硬解视频画质模糊、严重涂抹得像油画、水彩画的问题
  • 冲击美团!已成功 OC
  • 重磅!望繁信科技与德勤中国签署战略合作协议
  • OneThink ThinkCMS think.cms
  • 如何基于 Python 快速搭建 QQ 开放平台 QQ 群官方机器人详细教程(更新中)
  • C语言[数组作函数参数]
  • 论文《Text2SQL is Not Enough: Unifying AI and Databases with TAG》
  • Java AI赋能MJ绘画系统开启创意绘图新纪元
  • Spring AI Alibaba 接入国产大模型通义千问
  • C:浅谈数组指针的声明
  • CODESYS面向对象编程:方法/动作/属性的使用
  • MyBatis 动态 SQL 详解
  • Mac通过键盘选取内容
  • 京东云主机和云服务器有啥区别?轻量云主机就是轻量应用服务器吗?
  • 编写Python 自动化安装openGauss 数据库方法和代码 (2)
  • Lua条件语句