代码随想录算法训练营数组总结

一、理论基础


定义:数组是存放在连续内存空间上的相同类型数据的集合。
注意事项:

①数组下标从0开始。

②数组元素不能删除,只能覆盖。

③二维数组的地址空间不一定是连续的。

二、方法总结


1.二分法

思想:设置left、right指针,确定临界区间,一般分为以下两种。

左闭右闭:left = 0, right = nums.length - 1, while(left<=right), left = mid+1, right = mid-1

左闭右开:left = 0, right = nums.length, while(left < right).left = mid+1, right = mid
相关题目:LeetCode 704.二分查找 35.搜索插入位置

34.在排序数组中查找第一个和最后一个元素的位置

2.双指针

思想:设置快慢指针fast、slow,在一个for循环内完成两个for循环的任务。
相关题目:LeetCode 27.移除元素 977.有序数组的平方

3.滑动窗口

思想:以子序列的结束位置作为遍历索引、根据当前子序列的情况,不断调整子序列的起始位置。
相关题目: LeetCode 209.长度最小的子数组

4.模拟过程

思想:依据题意设置合适数量的指针及边界控制符,模拟实现过程从而完成求解。
相关题目:LeetCode 59.螺旋矩阵

三、个人总结


二分法:关键在于开闭区间与左右指针的匹配,掌握较好。

双指针:关键在于设置快慢指针移动条件,掌握较好。

滑动窗口:关键在于确定窗口起始位置移动条件,掌握一般,需加强练习。

模拟过程:画图对解题帮助较大,掌握良好。

相关推荐
Yzzz-F44 分钟前
Problem - 2205D - Codeforces
算法
极客先躯1 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户60648767188961 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java
我命由我123451 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
aXin_ya1 小时前
微服务第八天 Sentinel 四种分布式事务模式
java·数据库·微服务
智者知已应修善业1 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn1 小时前
Java Set集合相关知识点
java·开发语言·算法
Linsk2 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
许彰午2 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
zhouwy1132 小时前
Java 快速入门笔记:从基础语法到 Spring Boot 实战
java