问题

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3618 访问。

给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。

注意:答案中不可以包含重复的三元组。

例如, 给定数组 nums = [-1, 0, 1, 2, -1, -4],

满足要求的三元组集合为: [ [-1, 0, 1], [-1, -1, 2] ]


Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.

Note:The solution set must not contain duplicate triplets.

Given array nums = [-1, 0, 1, 2, -1, -4],

A solution set is: [ [-1, 0, 1], [-1, -1, 2] ]

示例

public class Program {

    public static void Main(string[] args) {
var intervals = new int[] { -1, 0, 1, 2, -1, -4 }; var res = ThreeSum(intervals);
ShowArray(res); intervals = new int[] { 0, 0, 0 }; res = ThreeSum2(intervals);
ShowArray(res); Console.ReadKey();
} private static void ShowArray(IList<IList<int>> list) {
foreach(var nums in list) {
foreach(var num in nums) {
Console.Write($"{num} ");
}
Console.WriteLine();
}
} public static IList<IList<int>> ThreeSum(int[] nums) {
//暴力解法肯定超时无法AC
var res = new List<IList<int>>();
for(int i = 0; i < nums.Length; i++) {
for(int j = 0; j < nums.Length; j++) {
for(int k = 0; k < nums.Length; k++) {
if(nums[i] + nums[j] + nums[k] == 0 &&
i != j && j != k && k != i) {
var line = new List<int> { nums[i], nums[j], nums[k] };
line = line.OrderBy(r => r).ToList();
if(!res.Any(l => l[0] == line[0] &&
l[1] == line[1] &&
l[2] == line[2])) {
res.Add(line);
}
}
}
}
}
return res;
} public static IList<IList<int>> ThreeSum2(int[] nums) {
//先固定 i,再计算三数之和是不是0
//需认真分析是否有重复的三元组
var res = new List<IList<int>>();
var length = nums.Length;
Array.Sort(nums);
for(var i = 0; i < length - 2; i++) {
//定义左右指针j和k
//i为循环变量,可以认为先固定了i
var j = i + 1;
var k = length - 1;
//分析j和k
while(j < k) {
//若和大于0,则需要减整体的值,将右指针 k 减1
if(nums[i] + nums[j] + nums[k] > 0) k--;
//若和小于0,则需要加整体的值,将左指针 j 加1
else if(nums[i] + nums[j] + nums[k] < 0) j++;
else {
//若和正好等于0,将其存放进结果中
//然后需要处理重复三元组的情况
//不重复三元组需要3个索引各不相同并且组成的值的结果不能重复
//以下3个条件组成了满足不重复三元组的所有条件
//条件1:i、j、k的顺序具有稳定性,总是从小到大
res.Add(new int[] { nums[i], nums[j], nums[k] });
//首先使用 j + 1 <= nums.Length - 1 保证数组不越界
//条件2:再向右找到第1个值不和当前左指针相同的值的索引
//若为 1,1,1,1,1,2,找到2
while(j + 1 <= nums.Length - 1 && nums[j + 1] == nums[j++]) { }
}
}
//条件3:向右找到最后1个和当前被固定的 i 的值相同的值的索引
//若为 1,1,1,1,1,2,找到2前面的最后一个1
while(i + 1 <= nums.Length - 1 && nums[i + 1] == nums[i]) i++;
}
return res;
} }

以上给出2种算法实现,以下是这个案例的输出结果:

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3618 访问。

-1 0 1
-1 -1 2
0 0 0

分析

显而易见, ThreeSum 的时间复杂度为: O(n3)O(n^3)O(n3),ThreeSum2 的时间复杂度为:O(n2)O(n^2)O(n2) 。

C#LeetCode刷题之#15-三数之和(3Sum)的更多相关文章

  1. LeetCode 15. 三数之和(3Sum)

    15. 三数之和 15. 3Sum 题目描述 Given an array nums of n integers, are there elements a, b, c in nums such th ...

  2. Leetcode题库——15.三数之和

    @author: ZZQ @software: PyCharm @file: threeSum.py @time: 2018/10/6 19:47 说明:给定一个包含 n 个整数的数组 nums,判断 ...

  3. leetcode刷题笔记-1. 两数之和(java实现)

    题目描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,数组中同一个元素不能使 ...

  4. LeetCode 刷题笔记 1. 两数之和(Two Sum)

    tag: 栈(stack) 题目描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案. ...

  5. #leetcode刷题之路15-三数之和

    给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组. 注意:答案中不可以包含重复的三元组. ...

  6. #leetcode刷题之路1-两数之和

    给定两个整数,被除数 dividend 和除数 divisor.将两数相除,要求不使用乘法.除法和 mod 运算符.返回被除数 dividend 除以除数 divisor 得到的商. 示例 1:输入: ...

  7. (1)leetcode刷题Python笔记——两数之和

    题目如下: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数 ...

  8. #leetcode刷题之路18-四数之和

    给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满 ...

  9. C#LeetCode刷题之#633-平方数之和( Sum of Square Numbers)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3885 访问. 给定一个非负整数 c ,你要判断是否存在两个整数 ...

  10. Java实现 LeetCode 15 三数之和

    15. 三数之和 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组. 注意:答案中不可以 ...

随机推荐

  1. 用maven打包java项目的pom文件配置

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  2. 小白从零开始阿里云部署react项目+node服务接口(二:node服务+web)

    我们用极简的方式来创建服务,没有任何附加功能 1 新建一个server文件夹 2 使用npm init 或者yarn init  一路enter 3  yarn add  express cors  ...

  3. Ethical Hacking - GAINING ACCESS(2)

    Server Side Attacks - INFORMATION GATHERING Need an IP address. Very simple if target is on the same ...

  4. 前端学习(六):body标签(四)

    进击のpython ***** 前端学习--body标签 关于前面的都是大部分的标签内容 但是就像衣服一样,除了要有,还要放到适当的位置 我们先来看看一下网页的布局: 就可以看出来,网页都是一块一块的 ...

  5. JavaFX布局神器-SceneBuilder

    JavaFX允许开发使用FXML来设计和布局界面,跟Qt和Android的布局有点类似,JavaFX用SceneBuilder来设计和布局界面. SceneBuilder最新的下载地址:https:/ ...

  6. php iamp 接收邮件,收取邮件,获取邮件列表

    每次想写的时候吧,提笔忘字.等到再次使用,又得想半天,,,,,好尴尬. 这次一边做一边写. 心得,程序员从菜鸟往老鸟转变的重要一步,学英语,看文档,在此我万分感谢鸟哥,,,,没他php哪有官方的中文注 ...

  7. Python循环控制语句

    Python循环控制语句:主要有三种,break.continue 和 pass 语句. break   语句 :在语句块执行过程中,终止循环.并跳出整个循环. continue 语句  :在语句执行 ...

  8. Python元组内置函数

    Python元组内置函数: len(元组名): 返回元组长度 # len(元组名): # 返回元组长度 tuple_1 = (1,2,3,'a','b','c') print("tuple_ ...

  9. ZROI 提高十连测 Day1

    第一天的提高模拟测 考前特意睡了20min 还是歇菜了,果然自己菜是真实的. 题目质量海星 但是我都不会这是真的...题目由于是花钱买的这里就不放了 LINK:problem 熟悉我的人应该都知道账号 ...

  10. 剑指 Offer 58 - I. 翻转单词顺序

    本题 题目链接 题目描述 我的题解 方法一:库函数split() 要注意str.split()函数: 字符串str前有 n 个空格时,分割出来的字符串列表中会多出 n 个空字符串: 字符串str某两个 ...