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

沈阳男科医院排名前十网站优化招商

沈阳男科医院排名前十,网站优化招商,物流公司响应式网站建设,python制作网站开发18. 四数之和 原题链接:完成情况:解题思路:参考代码:错误经验吸取 原题链接: 18. 四数之和 https://leetcode.cn/problems/4sum/description/ 完成情况: 解题思路: /** * //HashMap只能记录…

18. 四数之和

  • 原题链接:
  • 完成情况:
  • 解题思路:
  • 参考代码:
  • 错误经验吸取

原题链接:

18. 四数之和
https://leetcode.cn/problems/4sum/description/

完成情况:

在这里插入图片描述

解题思路:

/**
* //HashMap只能记录key,value的结果
* //而不能记录产生这个结果的过程
*
* @param nums
* @param target
* @return
*/

思路全在代码注释里

参考代码:

package LeetCode算法题;import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;public class __18四数之和 {/***         //HashMap只能记录key,value的结果*         //而不能记录产生这个结果的过程** @param nums* @param target* @return*/public List<List<Integer>> fourSum(int[] nums, int target) {//参考之前的三数求和,以及四数直接结果求和,//难道是构造两两的两对,然后一个两对的集合,去和另外两个数去判断???List<List<Integer>> res = new ArrayList<List<Integer>>();int len = nums.length;if (nums == null || len < 4){return res;}Arrays.sort(nums);  //初始先将所有元素排好序,这样可以避免混乱的找要求数字for (int i=0;i<len-3;i++){if (i>0 && nums[i] == nums[i-1]){   //从第二个数开始判断continue;       //并且去重}//取完重复之后,固定一个点,剩下指针指向三个节点//然后进行左右判断if ((long)nums[i] + nums[i + 3] + nums[i + 2] + nums[i+1] > target){break;      //如果最左边四个数还比target大,那么说明已经没有数满足target了。}if ((long)nums[i] + nums[len - 3] + nums[len - 2] + nums[len-1] < target){//nums[i] + nums[len - 3] + nums[len - 2] + nums[len-1]continue;   //+最大的三个数,如果还小于的话,那么说明nums[i]还可以左走}/*int Left = i+1,Right = len -1;while (Left < Right){同三个数比大小,但这里是四个数,因此还剩三个数,所以需要指出三个指针*/for (int j = i+1;j<len-2;j++){if (j>i+1 && nums[j] == nums[j-1]){     //继续去重continue;}if ((long)nums[i] + nums[j] + nums[j+1] + nums[j+2] > target){//如果头四个数大于targetbreak;}if ((long)nums[i] + nums[j] + nums[len-2]+nums[len - 1] < target){//如果定了指针的左边两个数 + 右边的两个数   小于targetcontinue;   //说明左边的数,小了}/*int Left = i+1,Right = len -1;while (Left < Right){同三个数比大小,但这里是四个数,因此还剩三个数,所以需要指出三个指针*///然后仿照三个数比大小,锁定left,right去模仿移动//此时的指针,分别是i,j,left,rightint left = j+1,right = len - 1;while (left < right){long sum = (long)nums[i] + nums[j] + nums[left] + nums[right];if (sum == target){res.add(Arrays.asList(nums[i],nums[j],nums[left],nums[right]));while (left<right && nums[left] == nums[left+1]){left++;}left++;while (left < right && nums[right] == nums[right-1]){right--;}right--;}else if (sum<target) { //左边小了left++;}else {     //右边大了right--;}}}}return res;}
}

错误经验吸取

http://www.hengruixuexiao.com/news/48982.html

相关文章:

  • 淄博淘宝网站建设社群营销策略有哪些
  • 深圳网站建设制作公司排名百度关键词模拟点击软件
  • 椒江做阿里巴巴网站的公司百度推广登陆入口官网
  • 视频链接生成简述seo对各类网站的作用
  • 网站维护服务费免费营销培训
  • 在线网页代理太太猫温州seo结算
  • 电子商务网站开发实训总结辅导机构
  • 建微信网站模板seo网站的优化流程
  • 中山做网站的公司合肥网站优化推广方案
  • 起飞页做网站步骤成都爱站网seo站长查询工具
  • 不用代码做交互式网站如何查询百度收录
  • 在线代理浏览器网站重庆百度关键词优化软件
  • 武汉做网站做得好的设计工作室姓名查询
  • 江苏住房和城乡建设厅网站报考百度搜索排名怎么靠前
  • 做赌博我网站找第三方支付达州seo
  • 高校机关党委网站建设中国最新疫情最新消息
  • 网站开发黄色片宜昌网站seo
  • 正规的公司网站建设女教师网课入侵录屏冫
  • 厦门做网站多少钱买卖网站
  • 深圳旅游网站开发江门seo推广公司
  • 目前做的比较好的情趣用品网站免费接单平台
  • 公司建立网站青岛电话百度极速版推广
  • 广州冼村在哪里娄底地seo
  • 龙岩网站建设设计制作广东深圳疫情最新消息今天
  • 网站收录不增加网站流量统计分析
  • 网站建设课程总结友情链接英语
  • 电子商务网站开发 pdf最新百度快速排名技术
  • 域名的网站建设方案书独立网站
  • 成品直播大全观视频的技巧网站seo优化推广
  • 公司简介简短点的优化网站排名解析推广