【java算法专场】双指针(下)

611. 有效三角形的个数

目录

611. 有效三角形的个数

算法思路

算法代码

LCR 179. 查找总价格为目标值的两个商品

算法思路

 算法代码

HashSet

双指针

15. 三数之和

算法思路

算法代码 

18. 四数之和

​编辑算法思路

算法代码 


611. 有效三角形的个数

算法思路

 

算法代码

/*** 计算可能的三角形数量。** @param a 一个整数数组,数组中的元素代表三角形的边长。* @return 返回可能构成的三角形的数量。*/public int triangleNumber(int[] a) {// 如果数组为空,则无法构成任何三角形if(a.length==0) return 0;// 对数组进行排序,以便后续通过比较边长来判断是否可以构成三角形Arrays.sort(a);//给数组排序// 初始化计数器,用于记录可以构成的三角形的数量int count=0;// 用来计算三角形个数// 从最长的边开始检查,逐步减少边长,以找到所有可能的三角形组合int n= a.length-1;while(n>=2){// 使用双指针技术,左指针指向最短边,右指针指向最长边,中间的边长由数组排序决定int left=0;int right=n-1;while(left<right){// 如果当前选择的三条边满足构成三角形的条件,则增加计数器,并移动右指针// 如果a+b大于c,那么此时可以构成三角形,且在【left,right】内的所有情况都可以构成三角形//count+=right-left,right--if(a[left]+a[right]>a[n]){count+=right-left;right--;}else{// 如果不满足条件,则移动左指针,尝试其他可能的边长组合// 如果a+b小于c,那么此时无法构成三角形,让left++left++;}}// 检查完一组边长后,减少最长边的长度,继续检查下一组//当判断完后,让n--n--;}// 返回可以构成的三角形的总数量return count;}

LCR 179. 查找总价格为目标值的两个商品

算法思路

 

 算法代码

HashSet

 public int[] twoSum(int[] price, int target) {Set<Integer> set=new HashSet<>();int i=0;for(;i<price.length;i++){if(set.contains(target-price[i])){return new int[]{target-price[i],price[i]};}else{set.add(price[i]);}}return new int[]{-1,-1};}

双指针

/*** 使用双指针方法查找数组中两个数的和等于特定目标值的索引。* 这个方法避免了对每个可能的组合进行显式的迭代,通过调整左右指针来缩小搜索范围。** @param a 输入的整数数组。* @param target 目标值,我们需要找到两个数的和等于这个值。* @return 包含这两个数索引的数组。如果不存在这样的两个数,则返回{-1, -1}。*/public int[] twoSum(int[] a, int target) {// 初始化左指针为数组的起始位置// 利用双指针int left = 0;// 初始化右指针为数组的结束位置int right = a.length - 1;// 当左指针小于右指针时,执行循环while (left < right) {// 计算当前左右指针所指元素的和int sum = a[left] + a[right];// 如果和大于目标值,移动右指针,减小和if (sum > target) {right--;}// 如果和小于目标值,移动左指针,增大和else if (sum < target) {left++;}// 如果和等于目标值,返回当前左右指针的索引else {return new int[]{a[left], a[right]};}}// 如果没有找到合适的组合,返回{-1, -1}return new int[]{-1, -1};}

15. 三数之和

算法思路

算法代码 

    /*** 寻找数组中所有不重复的三元组,这些三元组的和为零。* * @param nums 输入的整数数组* @return 返回一个列表,包含所有和为零的不重复三元组*/public List<List<Integer>> threeSum(int[] nums) {// 初始化结果列表List<List<Integer>> res = new ArrayList<>();// 如果数组长度小于3,无法找到满足条件的三元组,直接返回空列表if (nums.length < 3) {return res;}// 初始化指针k,用于遍历数组int k = 0;// 遍历数组,直到k指向的元素后至少还有两个元素for (; k < nums.length - 2;) {// 初始化左指针left,指向k后的第一个元素int left = k + 1;// 初始化右指针right,指向数组最后一个元素int right = nums.length - 1;// 计算目标值,即要找到的三个数的和,这里取当前k指向的数的相反数int target = -nums[k];// 当左指针小于右指针时,进行循环while (left < right) {// 计算当前左指针和右指针指向的数的和int sum = nums[left] + nums[right];// 如果和大于目标值,说明右指针太靠右,需要向左移动if (sum > target) {right--;}// 如果和小于目标值,说明左指针太靠左,需要向右移动else if (sum < target) {left++;}// 如果和等于目标值,找到了一个满足条件的三元组else {// 将这个三元组添加到结果列表中res.add(Arrays.asList(nums[k], nums[left], nums[right]));// 移动左指针和右指针,继续寻找下一个满足条件的三元组left++;right--;// 跳过所有与当前左指针指向的数相同的元素,避免重复while (left < right && nums[left] == nums[left - 1]) {left++;}// 跳过所有与当前右指针指向的数相同的元素,避免重复while (left < right && nums[right] == nums[right + 1]) {right--;}}}// 移动k指针,继续寻找下一个可能的三元组k++;// 跳过所有与当前k指针指向的数相同的元素,避免重复while (k < nums.length - 2 && nums[k] == nums[k - 1]) {k++;}}// 返回结果列表return res;}

18. 四数之和

算法思路

考虑下面这种情况,我们需要给aim使用 long类型,并将target也强转为long

算法代码 

 /*** 寻找数组中所有不重复的四个数,使得它们的和等于指定的目标数。** @param nums 输入的整数数组。* @param target 目标和。* @return 返回一个列表,包含所有满足条件的四个数的组合。*/public List<List<Integer>> fourSum(int[] nums, int target) {List<List<Integer>> res = new ArrayList<>();// 如果数组长度小于4,无法找到四个数的组合,直接返回空结果if (nums.length < 4) {return res;}Arrays.sort(nums);// 双层循环遍历数组,第一层循环选择第一个数,第二层循环选择第二个数for(int t=0;t<nums.length-3;){for(int k=t+1;k<nums.length-2;){// 计算剩余两个数的目标和long aim=(long)target-nums[t]-nums[k];// 使用双指针法寻找剩余的两个数int left=k+1;int right=nums.length-1;// 当左指针小于右指针时,执行循环while(left<right){// 当前两个数的和int sum=nums[left]+nums[right];// 如果当前和小于目标和,左指针右移if(aim>sum) left++;// 如果当前和大于目标和,右指针左移else if(aim<sum) right--;// 如果当前和等于目标和,将四个数的组合添加到结果中else {res.add(Arrays.asList(nums[t],nums[k],nums[left],nums[right]));// 移动左指针和右指针,避免重复组合left++; right--;// 跳过所有与前一个数相同的数,避免重复组合while(left<right && nums[left]==nums[left-1]) left++;while(left<right && nums[right]==nums[right+1]) right--;}}// 移动第二个数的指针,避免重复组合k++;while(k<nums.length-2 && nums[k]==nums[k-1]) k++;}// 移动第一个数的指针,避免重复组合t++;while(t<nums.length-3 && nums[t]==nums[t-1]) t++;}return res;}

 以上就是双指针专题篇的内容,若有不足,欢迎指正~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/869733.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端面试题(CSS篇六)

一、浏览器如何判断是否支持 webp 格式图片 &#xff08;1&#xff09;宽高判断法。通过创建image对象&#xff0c;将其src属性设置为webp格式的图片&#xff0c;然后在onload事件中获取图片的宽高&#xff0c;如果能够获取&#xff0c;则说明浏览器支持webp格式图片。如果不能…

IAR 编译优化等级详解

目录 1.编译时优化器何时介入 2.编译优化等级汇总 3.优化项解读 3.1 代码移动 3.2 函数内联 3.3 循环交换 3.4 循环展开 3.5 公用表达式消除 3.6 链接阶段的优化 4 小结 大家好&#xff0c;这里是快乐的肌肉。 最近在迁移工程到IAR编译器上&#xff0c;发现编译优化…

AI赛道成功的“小”AI平台,都在做什么?

在深入了解30多家跨界拓展AI赛道业务的企业后&#xff0c;我们发现大家对目前的AI市场存在一定程度的误解&#xff1a;即认为在AI领域想要分一杯羹&#xff0c;只需要搞几个API&#xff0c;把大语言模型、绘画、视频、数字人等功能都放上去&#xff0c;可能就有机会占一席之地了…

递归 迷宫问题-java

1&#xff09;findWay方法是为了找出走出迷宫的路径&#xff0c;找到返回true&#xff0c;否则返回false 2&#xff09;&#xff08;i&#xff0c;j&#xff09;是老鼠的位置&#xff0c;初始化的位置为&#xff08;1&#xff0c;1&#xff09; 3&#xff09;因为是递归找路&am…

2024年网络监控软件排名|10大网络监控软件是哪些

网络安全&#xff0c;小到关系到企业的生死存亡&#xff0c;大到关系到国家的生死存亡。 因此网络安全刻不容缓&#xff0c;在这里推荐网络监控软件。 2024年这10款软件火爆监控市场。 1.安企神软件&#xff1a; 7天免费试用https://work.weixin.qq.com/ca/cawcde06a33907e6…

【Linux】一文看懂Linux静态库和动态库

文章目录 一、静态库&#xff08;Static Library&#xff09;二、动态库&#xff08;Dynamic Library&#xff09;三、静态库和动态库的比较四、静态库的制作与使用五、动态库的制作与使用六、如何区分链接的是动态库还是静态库 在Linux系统编程中&#xff0c;库是一组预先编写…

【全面讲解下Foxit Reader】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

3年经验的B端产品经理,应该是什么水平?

问你一个问题&#xff1a;你觉得3年经验的B端产品经理&#xff0c;应该是什么水平&#xff1f;很多朋友可能也没有仔细想过&#xff0c;自己3年后应该达到一个什么水平&#xff1f;能做什么体量的业务&#xff1f;要能拿多少薪资&#xff1f; 前几天和一个B端产品经理聊天&…

SQL之delete、truncate和drop区别

MySQL删除数据的方式都有哪些&#xff1f; 常用的三种删除方式&#xff1a;通过 delete、truncate、drop 关键字进行删除&#xff1b;这三种都可以用来删除数据&#xff0c;但场景不同。 一、从执行速度上来说 drop > truncate >> DELETE;二、从原理上讲 1、DELET…

ctfshow-web入门-文件上传(web161、web162、web163)远程包含

目录 1、web161 2、web162 3、web163 1、web161 先传配置文件&#xff0c;可以上传成功 因为我前面给的 .user.ini 都是带了图片头 GIF89a 的&#xff0c;前面的题这个图片头可以去掉&#xff0c;但是在这里如果去掉是不行的。 因此后面上传的东西我们都带上这个图片头&…

FPGA程序设计

在设计FPGA时&#xff0c;多运用模块化的思想取设计模块&#xff0c;将某一功能设计成module。 设计之前要先画一下模块设计图&#xff0c;列出输入输出接口&#xff0c;再进一步设计内部功能。 状态机要画图&#xff0c;确定每个状态和状态之间怎么切换。状态用localparam定…

宏碁F5-572G-59K3笔记本笔记本电脑拆机清灰教程(详解)

1. 前言 我的笔记本开机比较慢&#xff0c;没有固态&#xff0c;听说最近固态比较便宜&#xff0c;就想入手一个&#xff0c;于是拆笔记本看一下有没有可以安的装位置。&#xff08;友情提示&#xff0c;在拆机之前记得洗手并擦干&#xff0c;以防静电损坏电源器件&#xff09…

视频版权音乐处理☞AI分离人声、音效、背景音乐的需求和进展-2024

随着互联网的普及和短视频的兴起&#xff0c;视频内容的全球各大平台分发越来越普遍。然而&#xff0c;不同国家和地区的音乐版权、不同社媒平台拥有的版权和处理政策都存在差异&#xff0c;因此同一个视频在多渠道分发的时候就会产生版权侵权风险。如何既能满足全球多渠道、多…

【UE5】调用ASR接口,录制系统输出。录制音频采样率不匹配

暂时测出window能用。阿里的ASR接口当前仅支持8000和16000。UE默认采样44100。

补码一位乘法原理(布斯编码详讲)

最近在看补码乘法的时候&#xff0c;感觉到很奇怪的一点&#xff0c;那就是补码的一位乘法&#xff0c;就是上网查了大量的资料都没有理解到它真正的原理&#xff0c;总感觉还是不会。那么&#xff0c;补码乘法的原理到底是什么呢&#xff1f;而让我们一直困惑的点是哪里呢&…

9.3 栅格图层符号化单波段伪彩色渲染

文章目录 前言单波段伪彩色QGis设置为单波段伪彩色二次开发代码实现单波段伪彩色 总结 前言 介绍栅格图层数据渲染之单波段伪彩色渲染说明&#xff1a;文章中的示例代码均来自开源项目qgis_cpp_api_apps 单波段伪彩色 使用单波段假彩色渲染栅格图层能够使用配色方案&#xff…

昇思25天学习打卡营第22天 | Shufflenet图像分类

ShuffleNet图像分类 当前案例不支持在GPU设备上静态图模式运行&#xff0c;其他模式运行皆支持。 ShuffleNet网络介绍 ShuffleNetV1是旷视科技提出的一种计算高效的CNN模型&#xff0c;和MobileNet, SqueezeNet等一样主要应用在移动端&#xff0c;所以模型的设计目标就是利用有…

【Linux】进程(9):进程控制3(进程程序替换)

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家了解Linux进程&#xff08;9&#xff09;进程控制1&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 &#xff08;A&#xff09;什么是进程程序替换&#xf…

js实现图片放大镜功能,简单明了

写购物项目的时候&#xff0c;需要放大图片&#xff0c;这里用js写了一个方法&#xff0c;鼠标悬浮的时候放大当前图片 这个是class写法 <!--* Descripttion: * Author: 苍狼一啸八荒惊* LastEditTime: 2024-07-10 09:41:34* LastEditors: 夜空苍狼啸 --><!DOCTYPE …

7.10号小项目部分说明

总体说明 糖锅小助手 我这次主要对上次糖锅小助手界面添加了一个侧边栏&#xff08;侧边输入框放置了三个按钮&#xff0c;可以跳转到其他ai聊天界面&#xff0c;还可以退出聊天界面回到登录界面&#xff09;和一个日期输入框&#xff08;日期输入框获取时间&#xff0c;根据时…