【LeetCode】初级算法案例+java代码(数组篇)

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
对象存储 OSS,内容安全 1000次 1年
简介: 【LeetCode】初级算法案例+java代码(数组篇)

@TOC


# 1.删除排序数组的重复项 题目: ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/77efd71a1b1e4d2d9f3e6d5ac292f9f1.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) 代码: ```java public int removeDuplicates(int[] nums) { //当数组长度为0时,直接返回零即可 if (nums.length == 0) { return 0; } //如果数组长度大于0,则返回的数组长度至少为1,记录数先保存所存入的第一个元素 int record = nums[0]; int num = 1; //直接从数组的第二个元素开始判断 for (int i = 1; i < nums.length; i++) { //如果所遍历到的新元素不等于记录数所保存的值,说明出现的是新元素,则更新记录数,并将该数存储到所给数组前面,num即当前找到的第几个不重复的数 if (nums[i] != record) { nums[num]=nums[i]; num++; record=nums[i]; } } return num; } ``` ```java //官方做法 public int removeDuplicates(int[] nums) { int n = nums.length; if (n == 0) { return 0; } //slow用于记录当前找到的不重复数的数量,当数组长度大于0时,最起码有一个或以上的不重复的数 int fast = 1, slow = 1; while (fast < n) { //找到不重复的数,存储到数组的第slow个元素中 if (nums[fast] != nums[fast - 1]) { nums[slow] = nums[fast]; ++slow; } ++fast; } return slow; } ```
# 2.买卖股票的最佳时机II 题目: ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/51bfbd7c21ef49eabbec882a2855efe9.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) **解题思路:允许多次买卖,意味着所有的差价都可以赚到,所以题目就相当于求解可以赚到的最大总差价** **代码:** ```java // while循环 public class Solution { public int maxProfit(int[] prices) { if(prices.length==1){ return 0; } int reslut = 0; int i = 0; int j = 1; while (j=p1){ reslut += (p2-p1); } i++; j++; } return reslut; } } ``` ```java // for循环 class Solution { public int maxProfit(int[] prices) { int sum=0; //无论数组长度为0还是1,都无法赚钱 if(prices.length<=1){ return 0; } for(int i=1;iprices[i-1]){ sum+=prices[i]-prices[i-1]; } } return sum; } } ```
# 3.旋转数组 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/8c39152e196a4448af3a7369e913cc01.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) **解题思路:由于旋转数组具有周期性,所以可以采用取余法获取旋转次数,而后进行模拟,这样可以大量减少模拟次数** **代码:** ```java public void rotate(int[] nums, int k) { int length = nums.length; k = k%length; if(k!=0){ int firstIndex = k; int[] arr = nums.clone(); for (int i = 0; i < arr.length ; i++) { if(firstIndex>=nums.length){ firstIndex = 0; } nums[firstIndex] = arr[i]; firstIndex++; } } } ```
# 4.存在重复元素 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/b5eb8ad0a402465a89643b7e44ec7257.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) **代码:** ```java /** * 解题思路:我们知道set集合中的元素是不能有重复的,在添加的时候如果有重复的,会把之前的值给覆盖,并且返回false。 * 我们遍历数组中的所有值,一个个添加到集合set中,在添加的时候如果返回false,就表示有重复的,直接返回true。 */ public class Solution { public boolean containsDuplicate(int[] nums) { Set set = new HashSet<>(); for (int num : nums) { //因为集合set中不能有重复的元素,如果有重复的 //元素添加,就会添加失败 if (!set.add(num)) return true; } return false; } } ```
# 5.只出现一次的数字 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/8d8060e040644d84a9e95185f278de5f.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) **代码:** ```java /** * 解题思路:位运算解决 * 这题说的是只有一个数出现了一次,其他数字都出现了2次,让我们求这个只出现一次的数字。这题使用位运算是最容易解决的,关于位运算有下面几个规律 * 1^1=0; * 1^0=1; * 0^1=1; * 0^0=0; * 也就说0和1异或的时候相同的异或结果为0,不同的异或结果为1,根据上面的规律我们得到 * a^a=0;自己和自己异或等于0 * a^0=a;任何数字和0异或还等于他自己 * a^b^c=a^c^b;异或运算具有交换律 * 有了这3个规律,这题就很容易解了,我们只需要把所有的数字都异或一遍,最终的结果就是我们要求的那个数字。来看下代码 */ public class Solution { public int singleNumber(int[] nums) { int reduce = 0; for (int num : nums) { reduce = reduce ^ num; } return reduce; } } ```
# 6.两个数组的交集 II ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/c8cfb3a1305644aa8b670e4443bddfc8.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) **代码:** ```java public int[] intersect(int[] nums1, int[] nums2) { HashMap map = new HashMap<>(); for (int i = 0; i < nums1.length; i++) { if (!map.containsKey(nums1[i])) { map.put(nums1[i], 1); } else { map.replace(nums1[i], map.get(nums1[i]) + 1); } //或者使用以下方式 //map.put(nums1[i], map.getOrDefault(nums1[i], 0) + 1); } List numList = new ArrayList<>(); for (int num2 : nums2) { //当Map集合中存在这个key时,就使用这个key值,(若是数值型可以在此基础上进行运算) //如果没有就使用默认值defaultValue,即所设置的0 if (map.getOrDefault(num2,0)>0){ numList.add(num2); map.put(num2, map.get(num2) - 1); } } int[] arr = new int[numList.size()]; for (int i = 0; i < numList.size(); i++) { arr[i]=numList.get(i); } return arr; } ```
# 7.加一 ![\[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FH0pGoMX-1637932019434)(C:\Users\dam\AppData\Roaming\Typora\typora-user-images\image-20211126191406722.png)\]](https://ucc.alicdn.com/images/user-upload-01/9e0918ad940c45d9884d3430be4efd86.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) 代码: ```java public int[] plusOne(int[] digits) { //用来记录一个位数是否要执行加1操作,比如个位数是9,则十位数需要执行加一操作 int count = 1; for (int i = digits.length - 1; i >= 0; i--) { //大于9,下一位数还需要加一 if (digits[i] + count > 9) { digits[i] = 0; count = 1; } else { //小于等于9,下一位数无须再加一,count=0 digits[i] = digits[i] + count; count = 0; } } //当最后count==1时,说明数组长度不够,如999>1000 if (count == 1) { int[] arr = new int[digits.length + 1]; //只有首位是1 arr[0] = 1; return arr; } else { return digits; } } ```
# 8.移动零 ![\[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-akUMfqaI-1637932019435)(C:\Users\dam\AppData\Roaming\Typora\typora-user-images\image-20211126200642296.png)\]](https://ucc.alicdn.com/images/user-upload-01/56564e1d85bd463ca24338df35829cd1.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) 代码: ```java public void moveZeroes(int[] nums) { int length = nums.length; if (length <= 1) { return; } int fast = 0; int slow = 0; while (fast < length) { //不为零地数往前移动 if (nums[fast] != 0) { nums[slow] = nums[fast]; slow++; } fast++; } //后面的数置为0 while (slow map = new HashMap<>(); for (int i = 0; i < nums.length; i++) { if (map.getOrDefault(target - nums[i], -1) > -1) { return new int[]{map.get(target - nums[i]), i}; } map.put(nums[i],i); } return null; } ```
# 最后 ​ 数组是数据结构的基础结构,虽然看似简单,但也存在很多操作技巧,感兴趣的同学可以上[初级算法 - LeetBook - 力扣(LeetCode)全球极客挚爱的技术成长平台 (leetcode-cn.com)](https://leetcode-cn.com/)进行进一步的学习。
相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
目录
相关文章
|
1月前
|
JavaScript NoSQL Java
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
181 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
|
2月前
|
存储 算法 安全
探究‘公司禁用 U 盘’背后的哈希表算法与 Java 实现
在数字化办公时代,信息安全至关重要。许多公司采取“禁用U盘”策略,利用哈希表算法高效管理外接设备的接入权限。哈希表通过哈希函数将设备标识映射到数组索引,快速判断U盘是否授权。例如,公司预先将允许的U盘标识存入哈希表,新设备接入时迅速验证,未授权则禁止传输并报警。这有效防止恶意软件和数据泄露,保障企业信息安全。 代码示例展示了如何用Java实现简单的哈希表,模拟公司U盘管控场景。哈希表不仅用于设备管理,还在文件索引、用户权限等多方面助力信息安全防线的构建,为企业数字化进程保驾护航。
|
7天前
|
传感器 监控 Java
Java代码结构解析:类、方法、主函数(1分钟解剖室)
### Java代码结构简介 掌握Java代码结构如同拥有程序世界的建筑蓝图,类、方法和主函数构成“黄金三角”。类是独立的容器,承载成员变量和方法;方法实现特定功能,参数控制输入环境;主函数是程序入口。常见错误包括类名与文件名不匹配、忘记static修饰符和花括号未闭合。通过实战案例学习电商系统、游戏角色控制和物联网设备监控,理解类的作用、方法类型和主函数任务,避免典型错误,逐步提升编程能力。 **脑图速记法**:类如太空站,方法即舱段;main是发射台,static不能换;文件名对仗,括号要成双;参数是坐标,void不返航。
27 5
|
2月前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
419 11
|
2月前
|
存储 监控 Java
JAVA线程池有哪些队列? 以及它们的适用场景案例
不同的线程池队列有着各自的特点和适用场景,在实际使用线程池时,需要根据具体的业务需求、系统资源状况以及对任务执行顺序、响应时间等方面的要求,合理选择相应的队列来构建线程池,以实现高效的任务处理。
143 12
|
2月前
|
JSON Java 数据挖掘
利用 Java 代码获取淘宝关键字 API 接口
在数字化商业时代,精准把握市场动态与消费者需求是企业成功的关键。淘宝作为中国最大的电商平台之一,其海量数据中蕴含丰富的商业洞察。本文介绍如何通过Java代码高效、合规地获取淘宝关键字API接口数据,帮助商家优化产品布局、制定营销策略。主要内容包括: 1. **淘宝关键字API的价值**:洞察用户需求、优化产品标题与详情、制定营销策略。 2. **获取API接口的步骤**:注册账号、申请权限、搭建Java开发环境、编写调用代码、解析响应数据。 3. **注意事项**:遵守法律法规与平台规则,处理API调用限制。 通过这些步骤,商家可以在激烈的市场竞争中脱颖而出。
|
3月前
|
安全 Java 编译器
深入理解Java中synchronized三种使用方式:助您写出线程安全的代码
`synchronized` 是 Java 中的关键字,用于实现线程同步,确保多个线程互斥访问共享资源。它通过内置的监视器锁机制,防止多个线程同时执行被 `synchronized` 修饰的方法或代码块。`synchronized` 可以修饰非静态方法、静态方法和代码块,分别锁定实例对象、类对象或指定的对象。其底层原理基于 JVM 的指令和对象的监视器,JDK 1.6 后引入了偏向锁、轻量级锁等优化措施,提高了性能。
90 3
|
3月前
|
前端开发 Java 测试技术
java日常开发中如何写出优雅的好维护的代码
代码可读性太差,实际是给团队后续开发中埋坑,优化在平时,没有那个团队会说我专门给你一个月来优化之前的代码,所以在日常开发中就要多注意可读性问题,不要写出几天之后自己都看不懂的代码。
89 2
|
2天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于生物地理算法的MLP多层感知机优化matlab仿真
本程序基于生物地理算法(BBO)优化MLP多层感知机,通过MATLAB2022A实现随机数据点的趋势预测,并输出优化收敛曲线。BBO模拟物种在地理空间上的迁移、竞争与适应过程,以优化MLP的权重和偏置参数,提升预测性能。完整程序无水印,适用于机器学习和数据预测任务。
|
1天前
|
资源调度 算法 数据可视化
基于IEKF迭代扩展卡尔曼滤波算法的数据跟踪matlab仿真,对比EKF和UKF
本项目基于MATLAB2022A实现IEKF迭代扩展卡尔曼滤波算法的数据跟踪仿真,对比EKF和UKF的性能。通过仿真输出误差收敛曲线和误差协方差收敛曲线,展示三种滤波器的精度差异。核心程序包括数据处理、误差计算及可视化展示。IEKF通过多次迭代线性化过程,增强非线性处理能力;UKF避免线性化,使用sigma点直接处理非线性问题;EKF则通过一次线性化简化处理。

热门文章

最新文章