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

大连app网站建设沈阳网站seo排名公司

大连app网站建设,沈阳网站seo排名公司,论坛网站建设费用,网站建设的会计科目题目 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意:答案中不可以包含重复的三元组。 …

题目

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != 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 。

我的思路

var threeSum = function(nums) {var len = nums.length;var left,right;var ans = new Array();var map = new Map();var res;for(var i = 0;i<len-2;i++){for(var z=i+1;z<len-1;z++){left = nums[z];for(var j=i+2;j<len;j++){right = nums[j];if(nums[i]+left+right==0){res = [nums[i],left,right];if(map.has(res.sort((a,b)=>a-b))){continue;}else{ans.push([nums[i],left,right]);map.set(res.sort((a,b)=>a-b),1);}}}}}return ans;
};

题解

首先对数组进行排序,排序后固定一个数 nums[i],再使用左右指针指向 nums[i]后面的两端,数字分别为 nums[L]和 nums[R],计算三个数的和 sum 判断是否满足为 000,满足则添加进结果集
如果 nums[i]大于 0,则三数之和必然无法等于 0,结束循环
如果 nums[i] == nums[i−1],则说明该数字重复,会导致结果重复,所以应该跳过
当 sum == 0 时,nums[L] == nums[L+1] 则会导致结果重复,应该跳过,L++
当 sum == 0 时,nums[R] == nums[R−1] 则会导致结果重复,应该跳过,R−−。

/*** @param {number[]} nums* @return {number[][]}*/
var threeSum = function(nums) {let ans = [];const len = nums.length;if(nums == null || len < 3) return ans;nums.sort((a, b) => a - b); // 排序for (let i = 0; i < len ; i++) {if(nums[i] > 0) break; // 如果当前数字大于0,则三数之和一定大于0,所以结束循环if(i > 0 && nums[i] == nums[i-1]) continue; // 去重let L = i+1;let R = len-1;while(L < R){const sum = nums[i] + nums[L] + nums[R];if(sum == 0){ans.push([nums[i],nums[L],nums[R]]);while (L<R && nums[L] == nums[L+1]) L++; // 去重while (L<R && nums[R] == nums[R-1]) R--; // 去重L++;R--;}else if (sum < 0) L++;else if (sum > 0) R--;}}        return ans;
};

http://www.zhongyajixie.com/news/54562.html

相关文章:

  • 境外网站开发针对本地的免费推广平台
  • wordpress custom permalinksseo挖关键词
  • 找网站做网站做网站电子商务专业就业方向
  • 正规网站优化公司唐山建站公司模板
  • 中山 网站建设一条龙服务seo策略主要包括
  • phpmysql网站开发技术安卓优化大师
  • 用PS怎么做网站界面沈阳专业网站seo推广
  • 做ebay货物查找的网站平面设计正规培训机构
  • 怎样用别人的网站做修改短视频营销常用平台有
  • 珠海市住房城乡建设局网站免费域名 网站
  • 建筑网站免费竞价托管资讯
  • 做纸箱在什么网站找客户最近的新闻大事20条
  • 怎么给网站在百度地图上做爬虫sem是什么显微镜
  • 图书馆门户网站建设会议记录设计网站官网
  • 电子商务网站建设的要求每日新闻最新消息
  • 美图秀秀可以做网站吗百度医生
  • 怎么做淘宝优惠卷网站app优化网站
  • 网站多语言建设方案十大软件培训机构
  • web前端只做网站么网页制作免费网站制作
  • 免费模板下载免费版seo算法入门教程
  • 郑州做网站徐州seo顾问
  • 工业园做网站的公司合肥今日头条最新消息
  • 北京网站设计定制开发建设公司优化seo教程技术
  • 浙江公司响应式网站建设推荐windows10优化工具
  • 手机2345网址大全搜索引擎优化seo多少钱
  • 有专门做面包的网站么alexa排名查询
  • 太仓市建设局网站全国十大跨境电商公司排名
  • 备案做电影网站站长工具ping
  • 建网站靠什么赚钱郑州有没有厉害的seo顾问
  • 信誉好的集团网站建设目前最新的营销方式有哪些