当前位置:网站首页>leetcode 15. 三数之和
leetcode 15. 三数之和
2022-08-06 02:59:00 【_刘小雨】
作者简介:C/C++ 、Golang 领域耕耘者,创作者
个人主页:作者主页
活动地址:CSDN21天学习挑战赛
题目来源: leetcode官网
如果感觉博主的文章还不错的话,还请关注 、点赞 、收藏🧡三连支持一下博主哦~~~
题目描述
给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。
注意:答案中不可以包含重复的三元组。
示例1:
输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
示例2:
输入:nums = []
输出:[]
示例3:
输入:nums = [0]
输出:[]
🧡 算法分析
此题方法用双指针
双指针的思路核心是需要有序
算法步骤:
- 先固定一个数
num[i] - 去遍历剩下两个数,如果用暴力就是两重循环,加上固定的前一个数,就是三重循环,这样时间复杂度就会超时,这里遍历采用的方法是利用双指针前面遍历, 这样就能将两重循环降低为一重循环
- 另外还有一个问题就是需要考虑答案中不包含重复元素,我们在这里就需要降重, 简单做法就是在排序后的数列中与后面一个元素进行判断是否相等
- 下面的代码中位置i和位置j 都进行了判重,k由于确定了前两位的元素不重复,所以k不必要判重
代码实现
class Solution {
public:
vector<vector<int>> threeSum(vector<int>& nums) {
// 必须有序才能用双指针算法
vector<vector<int>> re;
sort(nums.begin(), nums.end());
for(int i = 0; i < nums.size(); i ++)
{
if(i > 0 && nums[i] == nums[i - 1]) continue; // 降重
for(int j = i + 1, k = nums.size() - 1; j < k; j ++)
{
if(j > i + 1 && nums[j] == nums[j - 1]) continue; // 降重
while(j < k - 1 && nums[i] + nums[j] + nums[k - 1] >= 0) k --; // 关键
if(nums[i] + nums[j] + nums[k] == 0)
{
re.push_back({
nums[i], nums[j], nums[k]});
}
}
}
return re;
}
};
执行结果:
时间复杂度分析
其中遍历一次, 时间复杂度为O(n)
如果觉得对你有帮助的话:
点赞,你的认可是我创作的动力!
🧡 收藏,你的青睐是我努力的方向!
️ 评论,你的意见是我进步的财富!
边栏推荐
猜你喜欢

js_数组对象改属排序(含并别排序)

面试官:同学,冒泡太简单了,要不手写一个【快速排序】吧...

Soul向港交所递交上市申请,持续发力社交元宇宙赛道

Wasabi Technologies领导团队新增日本和澳大利亚业务高管,以支持整个亚太区对热云存储的需求

LeetCode Daily 2 Questions 01: Sliding Window - Longest Look Without Repeating Characters

6、NeRF in the Wild

How to make a pictogram in PPT

【无标题】

1321_一份BootLoader xmodem部分的协议分析

Configuring Smart Link Load Balancing on Huawei Devices
随机推荐
[机缘参悟-61]:《兵者,诡道也》-3-孙子兵法解读-敌战计
如何做代码评审?
ansible 学习
缓存算法有哪些分类呢?
js_数组对象改属排序(含并别排序)
在线问题反馈模块实战(二十):实现文件批量导出到zip压缩包中功能
ansible copy 模块
Wejo加入MONET联盟,进一步推动国际移动出行创新
mavonEditor 导航目录点击锚点定位功能只有在全屏编辑模式下才有效的问题
js_array object change attribute name
ALV细节再梳理2022.8.5
FTX.US将收购股票清算平台Embed,拓展股票交易业务
网络安全辅助工具:免费MD5解密网站
After 6 years of testing, from the monthly salary of 6k to the current annual salary of 40w, I have summarized these experiences...
实际工作开发中C语言工程的目录结构分析
js_数组对象改属性名
Nanostar raises more than $200 million for battery material production
CAD一键添加审图批注、AUTOCAD——图形界线怎么设置
比亚迪7月份销量爆表,产品结构非常合理
SprinBoot自定义异常(统一异常处理)