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

哈希表-四数之和

代码随想录-刷题笔记

18. 四数之和 - 力扣(LeetCode)

内容:

请一定要看上一篇文章!因为本题跟上一道题逻辑一模一样!

哈希表-三数之和-CSDN博客

这道题跟上一道题的核心一模一样,三数之和可以进行一定程度的简化,变成O(n^2)级别的算法.

但是这道题 包括五数,六数,七数之后. N数之和 都是一个逻辑了。

只不过是进行一下套壳。

代码如下:

class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        Arrays.sort(nums);
        List<List<Integer>> result = new ArrayList<>();
        for(int i = 0 ; i< nums.length ; i++) {
            if(nums[i] > target && nums[i]>=0) break;
            if(i>0 && nums[i] == nums[i-1]) continue;

            for(int j = i+1 ;j < nums.length ;j++) {
                if(nums[j]+nums[i] > target && nums[j]+nums[i] >=0) break;
                if(j>i+1&&nums[j]==nums[j-1]) continue;

                int left = j + 1;
                int right = nums.length -1;
                while(right > left) {
                    if(nums[i]+nums[j]+nums[left]+nums[right] > target) {
                        right--;
                    }else if(nums[i]+nums[j]+nums[left]+nums[right] < target) {
                        left++;
                    }else{
                        result.add(new ArrayList<>(Arrays.asList(nums[i],nums[j],nums[left],nums[right])));
                        while(right>left && nums[right] == nums[right-1]) right--;
                        while(right>left && nums[left] == nums[left+1]) left++;
                        left++;
                        right--;
                    }
                }

            }
        }
        return result;
    }
}

总结:

上一篇三数之和搞好了就可以了。

相关文章:

  • ceph部署-14版本(nautilus)-使用ceph-ansible部署实验记录
  • 常用架构图:业务架构、产品架构、系统架构、数据架构、技术架构、应用架构、功能架构及信息架构
  • java 通过阿里物联网平台推送数据到显示屏
  • 【办公类-90-01】】20250213周计划四类活动的写法(分散运动、户外游戏、个别化(美工室图书吧探索室))
  • Spring Boot 的约定优于配置,你的理解是什么?
  • Spreadjs与GcExcel
  • 如何使用 HPjtune 分析 Java GC 日志并优化 JVM 性能
  • JS的map方法和Map对象
  • 自己搭建可以和deepseek对话的WEB应用
  • Cursor AI开发微信小程序教程
  • DeepSeek崛起:中国AI产业的颠覆者与重构者
  • vue学习笔记10
  • html+css设计情人节网页制作主页页面
  • Tree Search for Web Agents
  • Attanger: Zotfile 插件在 Zotero7 的平替
  • ElementUI 的组件 Switch(开关)如何让文字显示在按钮上
  • DeepSeek 助力 Vue 开发:打造丝滑的无限滚动(Infinite Scroll)
  • 机器视觉--数字图像格式
  • 如何正确安装Stable Diffusion Web UI以及对应的xFormers
  • 面试第二山!《计算机网络》!
  • 衡水企业网站建设/公众号怎么推广和引流
  • 网站开发与运营方向和企业管理方向/网页模板素材
  • 网站制作web678/企业宣传册
  • 网站两边广告/重庆seo顾问
  • 平度网站建设/浏览器老是出现站长工具
  • 服务器搭建网站空间/长沙网站推广公司