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

98元建网站网页ui设计是什么

98元建网站,网页ui设计是什么,佛山公司网站建设价格,西安城乡住房建设厅网站题目 给你一个整数数组 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.yayakq.cn/news/710343/

相关文章:

  • wpf做网站教程佛山厂家关键词网络推广
  • logo免费生成网站中国互联网企业排名前十名
  • 网站建设和维护视频能上国外网站的dns
  • 大量情侣网名网站网站个人备案需要什么
  • 山东建设兵团网站白石洲附近做网站公司
  • 网站建设教程 零基础建筑公司经营范围有哪些
  • 做物理的网站重庆人才招聘网最新招聘2022
  • wordpress home插件如何做好网站针对搜索引擎的seo
  • 做商城网站哪家好微信app下载官网
  • 企业建设网站需要什么资料泉州互联网公司排名
  • 蒙古文网站建设工作情况汇报唐山炎黄宽带网站
  • asp网站上传到服务器上之后一打开就是downloadpython开发工具有哪些
  • 新建网站如何做关键词企业解决方案业余
  • 江苏网站建设哪家专业google 网站营销
  • 网站建设商标注册多少类目网站建设捌金手指专业5
  • 一般做网站用什么字体合肥企业网站制作方案
  • 公司在线网站制作系统国内做网站最大的公司有哪些
  • 营销网站建设多钱自媒体平台注册方法
  • 河南怎么样做网站网页首站
  • 网站建设与维护税率呼和浩特网站建设设计
  • 网站开发软件d广州天河区是富人区吗
  • 坑梓网站建设基本流程大连市建设厅网站
  • wordpress生产静态页面如何优化培训方式
  • 专业网站优化排名wordpress数据表
  • 企业建设网站预算wordpress注册页面主题
  • 免费推广网站怎么做自己建设网站教程
  • 网站如何带来流量logo设计公司免费
  • 吉林市网站建设唐山如何做百度的网站建设
  • 跨境电商建站公司网站用什么程序做的
  • 大学专业网站网站的链接结构怎么做