数组-leetcode#15-找出三个数之和等于0的所有不重复序列

2024-05-30 04:58

本文主要是介绍数组-leetcode#15-找出三个数之和等于0的所有不重复序列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {vector<vector<int>> res;if(nums.size()<=0) return res;sort(nums.begin(),nums.end());//先排序for(int i=0;i<nums.size();i++){if(i>0 && nums[i]==nums[i-1]) continue;int k = nums.size()-1;//从后往前走for(int j=i+1;j<nums.size();j++){if(j>i+1 && nums[j]==nums[j-1]) continue;while(j<k && nums[k]+nums[j]+nums[i]>0){k--;//nums[i]<nums[j]<nums[k]}if(j==k) break;if(nums[k]+nums[j]+nums[i]==0)res.push_back({nums[i],nums[j],nums[k]});}}//return res;}
};

暴力算法,复杂度O(n^3),超时,最后我们还需要去重复等,使用排序方法,从小到大排序数组,然后依次确定第一个数,第二个数,第三个数,通过有序限制来防止重复,即我们要求三个数nums[i]<nums[j]<nums[k]:

(1)先排序数组

(2)循环找第一个数,下标记为i,范围在0-n-1;如果当前i下标的数等于前面i-1的数,那么就跳出本次循环,因为在i-1步之前,我们已经考虑过选择这个数作为第一个数了。

(3)确定第二个数,下标记为j,范围在i+1-n-1;同样的如果当前j下标的数等于前面j-1的数,那么就跳出本次循环,因为在j-1步之前,我们已经考虑过选择这个数作为第二个数了。

(4)查找第三个使得求和为0的数是否存在,下标记为j,范围是j+1到n-1;其实第二个数和第三个数是并列来找的,一次循环i中,k是从末尾n-1开始往数组头部移动,j是从i+1开始往数组尾部移动,在循环j内,当j<k,并且三个数之和大于0的时候,k--,往左移动,那么跳出循环时候,只有两种情况,j==k或者求和小于等于0,如果j==k说明没找到,如果求和等于0,说明找到了,把三个数组一个vector加入结果集合res,如果求和小于0,说明没必要再往左移动k了,因为排序后的前面求和只会更小。

(5)这里面去重复是通过判断当前下标与前一个元素是不是相当来做的,相当,就不需要做本次循环,当前面两个数都确定了,使得求和为0的第三个数也就确定了,所以从后往前找是否存在。

 

这篇关于数组-leetcode#15-找出三个数之和等于0的所有不重复序列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1015637

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi