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

p2p免费网站建设兰州网络推广优化怎样

p2p免费网站建设,兰州网络推广优化怎样,网站开发服务合同范本,西宁网站建设开发15. 三数之和 题目: 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 **注意:**答…

15. 三数之和

题目:

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != kj != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

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

示例:

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

提示:

  • 3 <= nums.length <= 3000
  • -105 <= nums[i] <= 105

解题:

方法一:排序+双指针

这道题相较于两数之和多了去重的部分,所以不适合使用哈希法来解题,而这道题不要求返回下标,所以可以考虑对数组进行排序。

去重逻辑的思考
a的去重

说到去重,其实主要考虑三个数的去重。 a, b ,c, 对应的就是 nums[i],nums[left],nums[right]

a 如果重复了怎么办,a 是 nums 里遍历的元素,那么应该直接跳过去。

但这里有一个问题,是判断 nums[i] 与 nums[i + 1]是否相同,还是判断 nums[i] 与 nums[i-1] 是否相同。这其实不一样如果我们的写法是 这样:

/*那我们就把 三元组中出现重复元素的情况直接pass掉了。 例如 {-1, -1 ,2} 这组数据,当遍历到第一个 -1 的时候,判断 下一个也是 -1,那这组数据就 pass 了。*/
if (nums[i] == nums[i + 1]) { // 去重操作continue;
}

我们要做的是 不能有重复的三元组,但三元组内的元素是可以重复的!

所以这里是有两个重复的维度。

那么应该这么写:

/*这么写就是当前使用 nums[i],我们判断前一位是不是一样的元素,在看 {-1, -1 ,2} 这组数据,当遍历到 第一个 -1 的时候,只要前一位没有 -1,那么 {-1, -1 ,2} 这组数据一样可以收录到 结果集里。*/
if (i > 0 && nums[i] == nums[i - 1]) {continue;
}
b与c的去重

如果去重的逻辑多加了对 right 和left 的去重:(代码中注释部分)

while (right > left) {if (nums[i] + nums[left] + nums[right] > 0) {right--;// 去重 rightwhile (left < right && nums[right] == nums[right + 1]) right--;} else if (nums[i] + nums[left] + nums[right] < 0) {left++;// 去重 leftwhile (left < right && nums[left] == nums[left - 1]) left++;} else {}
}

但细想一下,这种去重其实对提升程序运行效率是没有帮助的。

拿 right 去重为例,即使不加这个去重逻辑,依然根据 while (right > left)if (nums[i] + nums[left] + nums[right] > 0) 去完成 right-- 的操作。

多加了 while (left < right && nums[right] == nums[right + 1]) right--; 这一行代码,其实就是把 需要执行的逻辑提前执行了,但并没有减少 判断的逻辑。

最直白的思考过程,就是 right 还是一个数一个数的减下去的,所以在哪里减的都是一样的。

所以这种去重是可以不加的。 仅仅是把去重的逻辑提前了而已。

代码实现:
class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {vector<vector<int>> result;sort(nums.begin(), nums.end());// 找出a + b + c = 0// a = nums[i], b = nums[left], c = nums[right]for (int i = 0; i < nums.size(); i++) {// 排序之后如果第一个元素已经大于零,那么无论如何组合都不可能凑成三元组,直接返回结果就可以了if (nums[i] > 0) {return result;}// 错误去重a方法,将会漏掉-1,-1,2 这种情况/*if (nums[i] == nums[i + 1]) {continue;}*/// 正确去重a方法if (i > 0 && nums[i] == nums[i - 1]) {continue;}int left = i + 1;int right = nums.size() - 1;while (right > left) {// 去重复逻辑如果放在这里,0,0,0 的情况,可能直接导致 right<=left 了,从而漏掉了 0,0,0 这种三元组/*while (right > left && nums[right] == nums[right - 1]) right--;while (right > left && nums[left] == nums[left + 1]) left++;*/if (nums[i] + nums[left] + nums[right] > 0) right--;else if (nums[i] + nums[left] + nums[right] < 0) left++;else {result.push_back(vector<int>{nums[i], nums[left], nums[right]});// 去重逻辑应该放在找到一个三元组之后,对 b 和 c 去重while (right > left && nums[right] == nums[right - 1]) right--;while (right > left && nums[left] == nums[left + 1]) left++;// 找到答案时,双指针同时收缩right--;left++;}}}return result;}
};

复杂度分析

  • 时间复杂度:O(N2),其中 N 是数组 nums 的长度。
  • 空间复杂度:O(1)。
http://www.dtcms.com/wzjs/53458.html

相关文章:

  • 电子商务网站建设实训内容做网站优化哪家公司好
  • 元器件商城网站建设万网域名续费
  • 深圳的设计网站大全营销网络营销
  • 成都高新区网站建设网络推广公司专业网络
  • 个人备案的网站做企业内容网站seo资讯
  • 网站制作方案怎么写网络营销案例分享
  • iis发布网站 主目录重定向到url广州优化营商环境条例
  • 网站开发时app打开很慢网站案例分析
  • 运城网站推广下拉框关键词软件
  • 重庆网站建设服务网站推广计划方案
  • 丹东网站建设平台经典软文案例50字
  • ai做网站步骤附近电脑培训速成班一个月
  • 做网站备案成功之后改怎么操作百度客服24小时人工服务在线咨询
  • 少年宫网站建设模块nba最新排名东西部
  • 有赞分销商城关键词优化是什么工作
  • 宿迁做网站的公司google优化师
  • 网站开发过程的基本环节seo排名优化点击软件有哪些
  • 做的网站如何防止怕爬虫私域流量和裂变营销
  • 营销型门户网站广西seo
  • 大连经营性网站备案广告招商
  • 中华人民共和国商务部网站市场建设司外包网络推广营销
  • 营销型外贸网站制作社群营销方案
  • wordpress自定义分类法常州seo外包
  • 百度联盟怎么做自己的网站线上广告投放方式
  • 有哪些网站是做红酒批发的百度推广可以自己开户吗
  • 做网站公司那家好网站设计模板网站
  • 网站宣传与推广百度推广电话销售好做吗
  • 二维码生成器在线制作方法杭州seo哪家好
  • 建立自己的网站怎么样做广西网站seo
  • 网站内的地图导航怎么做如何宣传网站