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

算法7.0

15. 三数之和 - 力扣(LeetCode)

审题:不同位置的三个数  数字是可以相同的

是需要三个数的下标是不一样的

答案中不可以包含不重复的三元组:结合示例1 顺序不一样 但是里面的元素相同  算一种

三元组的顺序不重要:里面的元素的顺序不重要  只要加起来是0就可以了 

解法一:暴力解法    排序+暴力枚举+利用set去重

在暴力解法的前提下   总结最优解   所以了解暴力解法是必须的

暴力枚举 三元组的和 然后去重   如何完成去重操作?用set   

至少三层for循环   时间复杂度是n的立方  

解法二:

先排序  成为了有序数组      触发关键词:二分  双指针

和为s的两个数 算法6.0的时候学习过  可以用这个作为启示:

排序  固定一个数   在该数后面的区间内  利用双指针算法  快速找到两个和等于-1即可

但是这样并没有去重   所以加一步 

处理细节问题:   

去重    因为排序  有相同的数字已经挨在一起了  1 22 3  有一个2后面的2就不需要了

          依旧是找到一种结果后   left和right指针要跳过重复元素  这样就去重了

          固定的地方也需要去重      

         注意越界访问的情况 

不漏(利用双指针算法的区间里面不漏)(找到情况后继续缩小区间寻) 

小优化:固定的位置大于0了  后面一定和为小于0的是没有的

逻辑不复杂   代码细节很多 

下面是效果图和代码:

class Solution {public List<List<Integer>> threeSum(int[] nums) {//定义一个结果数组List<List<Integer>>  ret = new ArrayList<>();//排序Arrays.sort(nums);//利用双指针解决问题int n = nums.length;for(int i = 0; i<n ;) {if(nums[i]>0)  break;//小优化int left = i+1,right = n-1,target = -nums[i];while(left<right){int sum = nums[left]+nums[right];if(sum>target)  right--;else if(sum<target) left++;else {ret.add(new ArrayList<Integer>(Arrays.asList(nums[i],nums[left],nums[right])));//缩小区间继续寻找left++;  right--;//去重//处理数组越界异常  条件里面加上一个判断left<rightwhile(left<right && nums[left]==nums[left-1])  left++;while(left<right && nums[right]==nums[right+1]) right--;}}//去重固定的数i++;//for循环条件里面就是因为这个语句干掉的 while(i<n && nums[i]==nums[i-1]) i++;}return ret ; }
}
//数组长度最后单独写一个变量定义  int n = arr.length;
//两数之和的时候  直接把target定义为负数  省去后面的绝对值的方法 
//定义一个结果数组 并且添加到数组里面的一种方法   List<List<Integer>>  ret = new ArrayList<>();  ret.add(new ArrayList<Integer>(Arrays.asList(nums[i],nums[left],nums[right])));
//有关去重的操作
//for循环里面的i++干掉  因为for循环逻辑执行之后里面固定数i已经往前面一步了  for里面的东西可以去掉//xiyu20251012&1#1*7

http://www.dtcms.com/a/473651.html

相关文章:

  • 【异常处理——下】
  • axios请求
  • 109、23种设计模式之迭代器模式(18/23)
  • 餐饮设计公司网站wordpress如何保存
  • 前端页面出现问题ResizeObserver loop completed with undelivered notifications.
  • 有声阅读网站如何建设邵阳学院研究生与学科建设处网站
  • AWS RDS Aurora MySQL高CPU使用率问题诊断与解决实战
  • 【Swift】LeetCode 11. 盛最多水的容器
  • 设计模式之 享元模式 Flyweight
  • 智械觉醒当AI开始思考“我是谁”
  • 商河 网站建设公司网站的具体的建设方案
  • 湖南省网站备案婚纱摄影网站应该如何做优化
  • pytest学习
  • seo网站建设厦门百度广告代理商查询
  • 【全连接神经网络】基本原理
  • Go 异步编程
  • 基于贪心最小化包围盒策略的布阵算法
  • 《Python 异步数据库访问全景解析:从阻塞陷阱到高性能实践》
  • AI 自己造“乐高积木”:生成式 AI 设计可拼装模块化硬件的实战笔记
  • 10.11笔记
  • 冒泡排序的多种实现方式详解
  • 网页设计平面设计温州网站优化页面
  • 特别分享:聊聊Git
  • M|蝙蝠侠:侠影之谜
  • crawl4ai智能爬虫(一):playwright爬虫框架详解
  • 探究Java、C语言、Python、PHP、C#与C++在多线程编程中的核心差异与应用场景
  • 国外网站模板网站建设ui培训班好
  • 瑞安建设公司网站旅游网站系统的设计与实现
  • MongoDB-基本介绍(一)基本概念、特点、适用场景、技术选型
  • 国产之光金仓数据库,真能平替MongoDB?实测来了!