全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  大数据学习笔记  >  详情

大数据之三数之和

来源:千锋教育
发布人:qyf
2022-12-07

推荐

在线提问>>

大数据之三数之和

  题目描述

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

  题目解析

  题目需要我们找出三个数且和为 0 ,那么除了三个数全是 0 的情况之外,肯定会有负数和正数,所以一开始可以先选择一个数,然后再去找另外两个数,这样只要找到两个数且和为第一个选择的数的相反数就行了。也就是说需要枚举 a 和 b ,将 c 的存入 map 即可。

  需要注意的是返回的结果中,不能有有重复的结果。这样的代码时间复杂度是 O(n^2)。在这里可以先将原数组进行排序,然后再遍历排序后的数组,这样就可以使用双指针以线性时间复杂度来遍历所有满足题意的两个数组合。

  代码实现

  class Solution {

  public:

  vector> threeSum(vector& nums) {

  vector> res;

  sort(nums.begin(), nums.end());

  if (nums.empty() || nums.back() < 0 || nums.front() > 0) return {};

  for (int k = 0; k < nums.size(); ++k) {

  if (nums[k] > 0) break;

  if (k > 0 && nums[k] == nums[k - 1]) continue;

  int target = 0 - nums[k];

  int i = k + 1. j = nums.size() - 1;

  while (i < j) {

  if (nums[i] + nums[j] == target) {

  res.push_back({nums[k], nums[i], nums[j]});

  while (i < j && nums[i] == nums[i + 1]) ++i;

  while (i < j && nums[j] == nums[j - 1]) --j;

  ++i; --j;

  } else if (nums[i] + nums[j] < target) ++i;

  else --j;

  }

  }

  return res;

  }

  };

相关文章

大数据之什么是数仓

2022-12-08

手写算法-懒汉式单例

2022-12-08

手写算法-四大排序

2022-12-08

是一个宽表好还是多个维表好?

2022-12-08

数据库和数据仓库的区别是什么?

2022-12-08

“未知”的数据对数据分析和可视化有什么影响?好处和坏处是什么?

2022-12-08
在线咨询 免费试学 教程领取