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

【算法】代码随想录之数组(更新中)

文章目录

前言

一、二分查找法(LeetCode--704)

二、移除元素(LeetCode--27)


前言

跟随代码随想录,学习数组相关的算法题目,记录学习过程中的tips。


一、二分查找法(LeetCode--704)

【1】算法功能:在有序数组中,查找指定元素,时间复杂度为O(log N)。

【2】算法思想:定义首尾指针分别指向数组的首尾元素,若中间元素的值小于目标值则将首指针移动至中间元素右侧,若中间元素的值大于目标值则将尾指针移动至中间元素的左侧,若相等则返回下标。

【3】代码实现:在左闭右闭的区间内查找。

class Solution {
public:int search(vector<int>& nums, int target) {int low = 0, high = nums.size() - 1;while (low <= high) {int mid = (low + high) / 2;if (nums[mid] == target) {return mid;} else if (nums[mid] < target) {low = mid + 1;} else {high = mid - 1;}}return -1;}
};

【4】易错点:①注意while循环的判定条件;②注意high的更新条件。


二、移除元素(LeetCode--27)

在之前的刷题中已经遇到过,且代码随想录的解法与当时我的初次解法相同,见【LeetCode算法】第27题:移除元素-CSDN博客。


http://www.lryc.cn/news/396492.html

相关文章:

  • Win-ARM联盟的端侧AI技术分析
  • MySQL常见的几种索引类型及对应的应用场景
  • 如何利用java依赖jave-all-deps实现视频格式转换
  • 三端保险丝-锂电池BMS二次保护器件
  • 用户增长 - 私域 - 社群运营自检清单SOP(社群运营30问)
  • 算法·高精度
  • Docker搭建kafka+zookeeper以及Springboot集成kafka快速入门
  • 【cocos2dx】【iOS工程】如何保存用户在游戏内的绘画数据,并将数据以图像形式展示在预览界面
  • 拥抱应用创新,拒绝无谓的模型竞争
  • 【源码+文档+调试讲解】旅游资源网站
  • Monaco 多行提示的实现方式
  • SpringMVC的架构有什么优势?——表单和数据校验(四)
  • Linux实战记录
  • 时间、查找、打包、行过滤与指令的运行——linux指令学习(二)
  • android CameraX构建相机拍照
  • 【普中】基于51单片机的矩阵电子密码锁LCD1602液晶显示 proteus仿真+程序+设计报告+讲解视频
  • 工厂水电燃气表流量计等能耗计量仪表非侵入式拍照抄表的方案
  • LLM大模型应用中的安全对齐的简单理解
  • clickhouse-jdbc-bridge rce
  • java中Comparator函数的用法实例?
  • mysql实战入门-基础篇
  • 阶段三:项目开发---民航功能模块实现:任务24:航空实时监控
  • 手机容器化 安装docker
  • 科普文:深入理解Mybatis
  • 称重传感器有哪些种类
  • 程序员鱼皮的保姆级写简历指南第四弹,优秀简历参考
  • UML建模案例分析-时序图和类图的对应关系
  • Java版Flink使用指南——从RabbitMQ中队列中接入消息流
  • Python酷库之旅-第三方库Pandas(013)
  • Linux 高级 Shell 脚本编程:掌握 Shell 脚本精髓,提升工作效率