代码随想录算法训练营第一天| 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;
    }
};


收获

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

相关文章
|
19天前
|
算法 索引
【算法】——二分查找合集
二分查找基础模版和进阶模版,查找元素位置,搜索插入位置,x的平方根,山脉数组的峰顶索引,寻找峰值,点名
|
1月前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
76 1
|
2月前
|
存储 缓存 算法
通过优化算法和代码结构来提升易语言程序的执行效率
通过优化算法和代码结构来提升易语言程序的执行效率
|
2月前
|
算法
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
|
7天前
|
算法 数据安全/隐私保护
室内障碍物射线追踪算法matlab模拟仿真
### 简介 本项目展示了室内障碍物射线追踪算法在无线通信中的应用。通过Matlab 2022a实现,包含完整程序运行效果(无水印),支持增加发射点和室内墙壁设置。核心代码配有详细中文注释及操作视频。该算法基于几何光学原理,模拟信号在复杂室内环境中的传播路径与强度,涵盖场景建模、射线发射、传播及接收点场强计算等步骤,为无线网络规划提供重要依据。
|
20天前
|
机器学习/深度学习 算法
基于改进遗传优化的BP神经网络金融序列预测算法matlab仿真
本项目基于改进遗传优化的BP神经网络进行金融序列预测,使用MATLAB2022A实现。通过对比BP神经网络、遗传优化BP神经网络及改进遗传优化BP神经网络,展示了三者的误差和预测曲线差异。核心程序结合遗传算法(GA)与BP神经网络,利用GA优化BP网络的初始权重和阈值,提高预测精度。GA通过选择、交叉、变异操作迭代优化,防止局部收敛,增强模型对金融市场复杂性和不确定性的适应能力。
156 80
|
8天前
|
机器学习/深度学习 数据采集 算法
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a实现时间序列预测,采用CNN-GRU-SAM网络结构。卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征。完整代码含中文注释和操作视频,运行效果无水印展示。算法通过数据归一化、种群初始化、适应度计算、个体更新等步骤优化网络参数,最终输出预测结果。适用于金融市场、气象预报等领域。
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
|
8天前
|
算法
基于龙格库塔算法的锅炉单相受热管建模与matlab数值仿真
本设计基于龙格库塔算法对锅炉单相受热管进行建模与MATLAB数值仿真,简化为喷水减温器和末级过热器组合,考虑均匀传热及静态烟气处理。使用MATLAB2022A版本运行,展示自编与内置四阶龙格库塔法的精度对比及误差分析。模型涉及热传递和流体动力学原理,适用于优化锅炉效率。
|
6天前
|
移动开发 算法 计算机视觉
基于分块贝叶斯非局部均值优化(OBNLM)的图像去噪算法matlab仿真
本项目基于分块贝叶斯非局部均值优化(OBNLM)算法实现图像去噪,使用MATLAB2022A进行仿真。通过调整块大小和窗口大小等参数,研究其对去噪效果的影响。OBNLM结合了经典NLM算法与贝叶斯统计理论,利用块匹配和概率模型优化相似块的加权融合,提高去噪效率和保真度。实验展示了不同参数设置下的去噪结果,验证了算法的有效性。