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

代码随想录 哈希 test 8

18. 四数之和 - 力扣(LeetCode)

        与三数之和类似,重点在剪枝和去重的区别,由于target可正可负,因此需要分两种情况讨论,如果target为正,则若当前选择的元素之和大于target,需要跳出这种选择,如果target为负,则若当前选择的元素之和大于target,需要跳出这种选择,可以将这两种情况简化(不完全相同)为判断当前选择的元素之和大于target且选择的元素之和>=0(目标值为-100,若元素为-99,-1,0也可以成立),去重与之前类似,注意选择第二个元素时同样需要类似的剪枝。

class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> res;sort(nums.begin(), nums.end());for(int j = 0; j < nums.size(); j++){if(nums[j] > target && nums[j] >= 0) break;if(j > 0 && nums[j] == nums[j-1]) continue;for(int i = j + 1; i < nums.size(); i++){if(nums[i] + nums[j] > target && nums[i] + nums[j] >= 0) break;if(i > j + 1 && nums[i] == nums[i - 1]) continue;int l = i + 1, r = nums.size() - 1;while(l < r){if((long)nums[j] + nums[i] + nums[l] + nums[r] < target) l++;else if((long)nums[j] + nums[i] + nums[l] + nums[r] > target) r--;else{res.push_back({nums[j],nums[i], nums[l], nums[r]});while(r > l && nums[l + 1] == nums[l]) l++;while(r > l && nums[r - 1] == nums[r]) r--;l++, r--;}}}}return res;}
};


http://www.mrgr.cn/news/83319.html

相关文章:

  • 使用VUE3创建个人静态主页
  • RNN心脏病预测-Pytorch版本
  • Facebook元宇宙项目中的智能合约应用:提升虚拟空间的自治能力
  • DXO公布OPPO Find X8系列电池性能:标准版超越Pro版
  • 机器学习之贝叶斯分类器和混淆矩阵可视化
  • 前端批量下载文件
  • 【神经网络中的激活函数如何选择?】
  • 使用 Maxwell 计算母线的电动势
  • 赛车微型配件订销管理系统(源码+lw+部署文档+讲解),源码可白嫖!
  • Formality:工具生成的文件
  • 初学stm32 --- DAC输出
  • 51c~Pytorch~合集4
  • Ansys Fluent Aeroacoustics 应用
  • Java Web开发进阶——Spring Security基础与应用
  • 操作系统之文件系统
  • 2025年XR行业展望:超越虚拟,融合现实
  • 词作词汇积累:错付、大而无当、语焉不详、愈演愈烈
  • 内核模块里访问struct rq及获取rq_clock_task时间的方法
  • 计算机毕业设计PyHive+Hadoop深圳共享单车预测系统 共享单车数据分析可视化大屏 共享单车爬虫 共享单车数据仓库 机器学习 深度学习
  • pytorch模型的保存失敗しましたが、
  • [大模型]本地离线运行openwebui+ollama容器化部署
  • 全解:Redis RDB持久化和AOF持久化
  • C#里使用libxl里演示输出日期和读取日期数据的例子
  • 30天开发操作系统 第 12 天 -- 定时器 v1.0
  • 【k8s】scc权限 restricted、anyuid、privileged
  • ARIMA模型 (AutoRegressive Integrated Moving Average) 算法详解与PyTorch实现