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

国内ui做的好的网站有哪些如何做好网络销售技巧

国内ui做的好的网站有哪些,如何做好网络销售技巧,网站制作 潍坊,专业html5网站建设给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意:答案中不可以包含重复的三元组。 示例 1…

给你一个整数数组 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] 。
注意,输出的顺序和三元组的顺序并不重要。

堆排序+双指针

class Solution {public List<List<Integer>> threeSum(int[] nums) {heapSort(nums); List<List<Integer>> ans = new ArrayList<List<Integer>>();int length = nums.length;for(int i = 0;i < length;i++){if(i > 0 && nums[i] == nums[i-1]){continue;}int k = length - 1;for(int j = i + 1;j < length;j++){if(j > i + 1 && nums[j] == nums[j-1]){continue;}while(k > j && nums[k] + nums[j] > -nums[i]){k--;}if(k == j){break;}if(nums[i] + nums[k] + nums[j] == 0){List<Integer> list = new ArrayList<Integer>();list.add(nums[i]);list.add(nums[j]);list.add(nums[k]);ans.add(list);}}}return ans;}public static void heapSort(int[] nums){int length = nums.length;for(int i = length / 2 - 1;i >= 0;i--){my_Sort(nums,i,length);}for(int i = length - 1;i >= 0;i--){int temp = nums[0];nums[0] = nums[i];nums[i] = temp;my_Sort(nums, 0, i);}}public static void my_Sort(int[] nums,int parent,int length){int child = 2*parent + 1;int temp = nums[parent];while(child < length){if(child + 1 < length && nums[child + 1] > nums[child]){child++;}if(temp >= nums[child]){break;}nums[parent] = nums[child];parent = child;child = 2*parent + 1;}nums[parent] = temp;}
}
  1. 首先调用heapSort方法对输入数组nums进行堆排序。
  2. 创建一个空的列表ans用于存储结果。
  3. 遍历排序后的数组,对于每个元素nums[i],如果与前一个元素相同则跳过,避免重复解。
  4. 设置两个指针jk,其中ji+1开始遍历,k从数组末尾开始向前移动。
  5. 如果j与前一个元素相同则跳过,避免重复解。
  6. 在循环中,当nums[k] + nums[j] > -nums[i]时,将k向前移动一位,缩小搜索范围。
  7. 如果k == j,说明没有找到满足条件的三元组,跳出内层循环。
  8. 如果nums[i] + nums[k] + nums[j] == 0,说明找到了一组满足条件的三元组,将其添加到结果列表ans中。
  9. 最后返回结果列表ans

heapsort堆排序部分的实现使用了递归的方式,首先构建大顶堆,然后将堆顶元素与最后一个元素交换,再调整剩余元素形成新的大顶堆,重复这个过程直到整个数组有序。

http://www.ds6.com.cn/news/68104.html

相关文章:

  • 有没有教做黄色网站厦门seo推广优化
  • 亚运会110周年庆典在杭州举行长沙网站优化方法
  • 苏州企业网站建设专家站点查询
  • 网站代付系统怎么做放心网站推广优化咨询
  • 北京免费网站建设模板大数据培训班出来能就业吗
  • 水友做的yyf网站全网热度指数
  • 旧域名新网站品牌推广的方式
  • 做前端的女生压力大吗seo黑帽培训骗局
  • 网站h1标签的应用好的竞价托管公司
  • 免费建网站系统西安百度网站排名优化
  • 郑州网站建设包括哪些品牌推广是做什么的
  • 河北网站建设报价韶山seo快速排名
  • 河北省住房与建设厅网站首页自助建站模板
  • 市桥做网站的公司做网络推广
  • 做网站需要去工商备案吗关键词快速排名平台
  • 网站建设缺乏个性小红书seo
  • 可以推广的网站有哪些百度产品大全首页
  • 手机触屏版网站管理系统营销型网站建设运营
  • 济宁网站建设推荐濮阳市网站建设
  • 做网站排名的公司有哪些杭州关键词优化测试
  • 网站设计风百度前三推广
  • 穿着丝袜做会更爽网站全国疫情排行榜最新情况列表
  • 北京疫情最新班级优化大师头像
  • 天津市做网站的公司有哪些国内10大搜索引擎
  • 做翻译兼职的网站海门网站建设
  • wordpress 政府模板关键词优化快速排名
  • 虚拟主机wordpress优化推广关键词
  • 新桥专业网站建设企业网站设计代码
  • wordpress卡核销宁德seo公司
  • 能不能自己做网站推广百度搜索引擎排行榜