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

四数之和-力扣

本题在三数之和的基础上,再增加一重循环进行解答

  • 首先注意的点是,一级剪枝处理,target > 0 && nums[i] >= target 此处只有整数才可剪枝处理,如果target为负数,nums[i] < target,也不能代表后续无解,因为数组排序后是一个升序的数组。
  • 二级去重,和一级去重类似,当当前元素与前一个相同时,则跳过
  • 二级剪枝处理,个人认为在一定情况下,似乎无需进行
  • 测试用例中有些数据的和,会超出int类型的范围,尝试在二级剪枝进行处理,但未能成功,只能选择在四数之和处使用long类型。

代码如下:

class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {sort(nums.begin(), nums.end());vector<vector<int>> fourSum;for(int i = 0; i < nums.size(); i++){if(target > 0 && nums[i] >= target){return fourSum;}if(i > 0 && nums[i] == nums[i - 1]){continue;}for(int j = i + 1; j < nums.size(); j++){if(j > i + 1 && nums[j] == nums[j - 1]){continue;}if(nums[i] + nums[j] > target && nums[i] >= 0){return fourSum;}int left = j + 1;int right = nums.size() - 1;while(left < right){if((long) nums[i] + nums[j] + nums[left] + nums[right] > target){right--;} else if((long) nums[i] + nums[j] + nums[left] + nums[right] < target){left++;} else{fourSum.push_back( {nums[i], nums[j], nums[left], nums[right]} );while(left < right && nums[right] == nums[right - 1]){right--;}right--;while(left < right && nums[left] == nums[left + 1]){left++;}left++;}}}}return fourSum;}
};
http://www.lryc.cn/news/357895.html

相关文章:

  • JS 中怎么删除数组元素?有哪几种方法?
  • Git如何将pre-commit也提交到仓库
  • vmware中Ubuntu虚拟机和本地电脑Win10互相ping通
  • 比较含退格的字符串-力扣
  • NSSCTF-Web题目4
  • 7. CSS 网格布局
  • 如何配置才能连接远程服务器上的 redis server ?
  • MindSpore实践图神经网络之环境篇
  • MVS net笔记和理解
  • Linux 编译屏障之 ACCESS_ONCE()
  • Discuz!X3.4论坛网站公安备案号怎样放到网站底部?
  • LPDDR6带宽预计将翻倍增长:应对低功耗挑战与AI时代能源需求激增
  • 云原生架构内涵_3.主要架构模式
  • 宏基因组分析流程(Metagenomic workflow)202405|持续更新
  • 一千题,No.0037(组个最小数)
  • PV PVC
  • 深入理解Nginx配置文件:全面指南
  • 【传知代码】自监督高效图像去噪(论文复现)
  • linnux上安装php zip(ZipArchive)、libzip扩展
  • 油封制品中各种橡胶材料的差异
  • 梳理清楚的echarts地图下钻和标点信息组件
  • 【busybox记录】【shell指令】readlink
  • C++之vector
  • 【简单介绍下idm有那些优势】
  • MyBatis系统学习 - 使用Mybatis完成查询单条,多条数据,模糊查询,动态设置表名,获取自增主键
  • Generative Action Description Prompts for Skeleton-based Action Recognition
  • 动手学深度学习(Pytorch版)代码实践 -深度学习基础-02线性回归基础版
  • 信息学奥赛初赛天天练-15-阅读程序-深入解析二进制原码、反码、补码,位运算技巧,以及lowbit的神奇应用
  • 期权具体怎么交易详细的操作流程?
  • 系统架构设计师【第3章】: 信息系统基础知识 (核心总结)