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

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

704 二分查找

  • 文章链接

https://programmercarl.com/0704.%E4%BA%8C%E5%88%86%E6%9F%A5%E6%89%BE.html#%E7%AE%97%E6%B3%95%E5%85%AC%E5%BC%80%E8%AF%BE

  • 什么是二分查找?

将一组有序数据分成两半,找出目标值所在的那一半,将其再次分成两半,如此往复,每一次拆分都会减小数据范围,最终找到目标值。

  • 代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left  = 0;
        int right = nums.size() - 1;
        int res = -1;
        while(left <=right){
            int middle = left + (right - left )/2;
            if(nums[middle] < target ){
                left = middle + 1;
            }else if(nums[middle] > target){
                right = middle - 1;
            }else{
                res = middle;
                break;
            }
        }
        return res;
    }
};
  • 思路

因为之前已经刷过几次,因为不是科班所以第一次见这类题的时候几乎蒙圈,看了随想录的讲解才有的解题思路。我的理解就是一半一半的拆。但是需要注意的是二分法的区间。左闭右开和左闭右闭两者对应的middle赋值方法是不一样的。防止混淆我一直用左闭右闭。

  • 感受

第三次刷这个题了,第一次艰难,第二次有些卡顿,第三次秒杀。加油。

27. 移除元素

  • 文章链接

代码随想录programmercarl.com/0027.%E7%A7%BB%E9%99%A4%E5%85%83%E7%B4%A0.html#%E7%AE%97%E6%B3%95%E5%85%AC%E5%BC%80%E8%AF%BE

  • 看到题目时的想法

没有什么头绪,练暴力解也要想半天

  • 看完解题思路后的想法

先看的暴力解,一目了然,不用看视频讲解。看了1分钟左右,马上开始暴力解。

然后看的单向双指针,也是一目了然,看完后很快就写出来了。(不是抄答案,理解思路独立coding)

相向双指针:看了代码还是不理解,自己在草稿上画了一下就理解了,讲的还是非常通透的。

  • 难点

不看文章一点不会,看了文章一点就通。难点主要是双向双指针的方法。

  • 代码

暴力解

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 ;j < size - 1;++j){
                    nums[j] = nums[ j +1];
                }
                size --;
                i--;
            }
        }
        return size;
    }
};

单向双指针

class Solution {
public:
//单向双指针
    int removeElement(vector<int>& nums, int val) {
        int slow_index = 0;
        for(int fastindex = 0;fastindex < nums.size() ;++fastindex){
            if(val != nums[fastindex]){
                nums[slow_index++ ] = nums[fastindex];
            }
        }
        return slow_index;
    }
};

相向双指针

class Solution {
public:
//相向双指针,左侧指针移动到val前一个index,把右侧不等于val的值放入val所在位置,右侧索引减一,如此往复直到结束
    int removeElement(vector<int>& nums, int val) {
        int left = 0;
        int right  = nums.size() - 1;
        while(left <= right){
            //寻找val所在的索引,目的为了存放后面不等于val的值
            while(left<=right && val != nums[left]){
                left++;
            }
            //找到一个val, right-1;该位置的值没必要放入left位置。
            while(left<=right && val ==nums[right]){
                right--;
            }
            //将后面不等于val的值移入val所在位置,同时right-1
            if(left<right){
                nums[left++] = nums[right --];
            }
        }
        return left;
    }
};


收获

日拱一卒,通透理解了二分查找和双指针方法

相关文章
|
6天前
|
机器学习/深度学习 存储 算法
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
近端策略优化(PPO)是深度强化学习中高效的策略优化方法,广泛应用于大语言模型的RLHF训练。PPO通过引入策略更新约束机制,平衡了更新幅度,提升了训练稳定性。其核心思想是在优势演员-评论家方法的基础上,采用裁剪和非裁剪项组成的替代目标函数,限制策略比率在[1-ϵ, 1+ϵ]区间内,防止过大的策略更新。本文详细探讨了PPO的基本原理、损失函数设计及PyTorch实现流程,提供了完整的代码示例。
114 10
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
|
2月前
|
算法 索引
【算法】——二分查找合集
二分查找基础模版和进阶模版,查找元素位置,搜索插入位置,x的平方根,山脉数组的峰顶索引,寻找峰值,点名
|
2月前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
3月前
|
存储 缓存 算法
通过优化算法和代码结构来提升易语言程序的执行效率
通过优化算法和代码结构来提升易语言程序的执行效率
|
4天前
|
算法 数据安全/隐私保护 计算机视觉
基于FPGA的图像双线性插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
本项目展示了256×256图像通过双线性插值放大至512×512的效果,无水印展示。使用Matlab 2022a和Vivado 2019.2开发,提供完整代码及详细中文注释、操作视频。核心程序实现图像缩放,并在Matlab中验证效果。双线性插值算法通过FPGA高效实现图像缩放,确保质量。
|
1月前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。
|
1月前
|
算法 数据可视化 安全
基于DWA优化算法的机器人路径规划matlab仿真
本项目基于DWA优化算法实现机器人路径规划的MATLAB仿真,适用于动态环境下的自主导航。使用MATLAB2022A版本运行,展示路径规划和预测结果。核心代码通过散点图和轨迹图可视化路径点及预测路径。DWA算法通过定义速度空间、采样候选动作并评估其优劣(目标方向性、障碍物距离、速度一致性),实时调整机器人运动参数,确保安全避障并接近目标。
148 68
|
3天前
|
算法
基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真
本程序基于海鸥优化算法(SOA)进行三维曲面最高点搜索的MATLAB仿真,输出收敛曲线和搜索结果。使用MATLAB2022A版本运行,核心代码实现种群初始化、适应度计算、交叉变异等操作。SOA模拟海鸥觅食行为,通过搜索飞行、跟随飞行和掠食飞行三种策略高效探索解空间,找到全局最优解。
|
1月前
|
算法 数据安全/隐私保护
室内障碍物射线追踪算法matlab模拟仿真
### 简介 本项目展示了室内障碍物射线追踪算法在无线通信中的应用。通过Matlab 2022a实现,包含完整程序运行效果(无水印),支持增加发射点和室内墙壁设置。核心代码配有详细中文注释及操作视频。该算法基于几何光学原理,模拟信号在复杂室内环境中的传播路径与强度,涵盖场景建模、射线发射、传播及接收点场强计算等步骤,为无线网络规划提供重要依据。

热门文章

最新文章