Leetcode 15三题之和

题目要求

题解

指针移动逻辑

去重逻辑

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        vector<vector<int>> res;
        int n = nums.size();
        if (n < 3) return res; // 不足3个元素直接返回空
        
        sort(nums.begin(), nums.end()); // 1. 排序
        
        for (int i = 0; i < n; ++i) {
            // 去重:如果当前数和前一个相同,跳过
            if (i > 0 && nums[i] == nums[i-1]) continue;
            
            int target = -nums[i]; // 要找的两数之和 = -nums[i]
            int left = i + 1;
            int right = n - 1;
            
            while (left < right) {
                int sum = nums[left] + nums[right];
                if (sum == target) {
                    // 找到一组解,加入结果
                    res.push_back({nums[i], nums[left], nums[right]});
                    
                    // 去重:跳过left方向的重复元素
                    while (left < right && nums[left] == nums[left+1]) left++;
                    // 去重:跳过right方向的重复元素
                    while (left < right && nums[right] == nums[right-1]) right--;
                    
                    // 移动指针继续找
                    left++;
                    right--;
                } else if (sum < target) {
                    left++; // 和太小,增大left
                } else {
                    right--; // 和太大,减小right
                }
            }
        }
        return res;
    }
};

// 测试
int main() {
    Solution sol;
    vector<int> nums = {-1, 0, 1, 2, -1, -4};
    vector<vector<int>> ans = sol.threeSum(nums);
    
    // 输出结果
    cout << "[";
    for (int i = 0; i < ans.size(); ++i) {
        cout << "[";
        for (int j = 0; j < 3; ++j) {
            cout << ans[i][j] << (j == 2 ? "" : ",");
        }
        cout << "]" << (i == ans.size()-1 ? "" : ",");
    }
    cout << "]" << endl; // 输出 [[-1,-1,2],[-1,0,1]]
    return 0;
}
相关推荐
生成论实验室几秒前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》导论:在破碎的世界寻找统一语法
人工智能·科技·算法·架构·创业创新
承渊政道1 分钟前
【动态规划算法】(两个数组的DP问题深度剖析与求解方法)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
杨连江5 分钟前
原子级平面限域协同晶核诱导定向生长单层鳞片石墨的研究
算法
MATLAB代码顾问11 分钟前
混合粒子群-模拟退火算法(HPSO-SA)求解作业车间调度问题——附MATLAB代码
算法·matlab·模拟退火算法
Felven15 分钟前
C. Prefix Min and Suffix Max
算法
加农炮手Jinx16 分钟前
LeetCode 26. Remove Duplicates from Sorted Array 题解
算法·leetcode·力扣
加农炮手Jinx16 分钟前
LeetCode 88. Merge Sorted Array 题解
算法·leetcode·力扣
格林威16 分钟前
线阵工业相机:如何计算线阵相机的行频(Line Rate)?公式+实例
开发语言·人工智能·数码相机·算法·计算机视觉·工业相机·线阵相机
yueyue54319 分钟前
透过现象看本质:以fast_lio架构的整套算法的局部避障改为TEB算法为例深度探讨——如何成为一个合格的算法架构师?
算法·架构
梨花爱跨境19 分钟前
红人视频×A10算法:亚马逊转化率与流量闭环实战
算法