C++算法练习-day18——15.三数之和

题目来源:. - 力扣(LeetCode)

题目思路分析

题目描述

给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有独特三元组,并返回所有独特三元组的列表。注意:答案中不可以包含重复的三元组。

解题思路

  1. 排序:首先对数组进行排序,这样可以方便后续的查找和去重。
  2. 固定一个数:遍历数组,固定一个数 nums[i],然后使用双指针法查找另外两个数 nums[j] 和 nums[k],使得 nums[i] + nums[j] + nums[k] = 0。
  3. 双指针法
    • 初始化两个指针,左指针 j = i + 1,右指针 k = n - 1。
    • 计算三数之和,根据和的大小调整指针位置:
      • 如果和小于 0,则左指针右移,增加和的值。
      • 如果和大于 0,则右指针左移,减少和的值。
      • 如果和等于 0,则找到了一个解,将结果添加到答案中,并移动指针以避免重复解。
  4. 去重:在遍历过程中,如果当前元素与前一个元素相同,则跳过,以避免重复解。

代码:

cpp 复制代码
#include <vector>  
#include <algorithm>  
  
class Solution {  
public:  
    std::vector<std::vector<int>> threeSum(std::vector<int>& nums) {  
        std::vector<std::vector<int>> ans;  
        int n = nums.size();  
          
        // 对数组进行排序  
        std::sort(nums.begin(), nums.end());  
          
        // 遍历数组,固定一个数  
        for (int i = 0; i < n - 2; ++i) {  
            // 去重:如果当前元素与前一个元素相同,则跳过  
            if (i > 0 && nums[i] == nums[i - 1]) {  
                continue;  
            }  
              
            // 初始化右指针  
            int k = n - 1;  
              
            // 使用双指针法查找另外两个数  
            for (int j = i + 1; j < n - 1; ++j) {  
                // 去重:如果当前元素与前一个元素相同,则跳过  
                if (j > i + 1 && nums[j] == nums[j - 1]) {  
                    continue;  
                }  
                  
                // 调整右指针位置,直到找到满足条件的三数之和  
                while (j < k && nums[i] + nums[j] + nums[k] > 0) {  
                    --k;  
                }  
                  
                // 如果左指针与右指针相遇,则结束内层循环  
                if (j == k) {  
                    break;  
                }  
                  
                // 如果找到满足条件的三数之和,则添加到答案中  
                if (nums[i] + nums[j] + nums[k] == 0) {  
                    ans.push_back({nums[i], nums[j], nums[k]});  
                }  
            }  
        }  
          
        return ans;  
    }  
};

知识点摘要

  1. 排序算法:使用排序算法(如快速排序、归并排序)对数组进行排序,以便后续操作。
  2. 双指针法:在有序数组中使用双指针法查找满足条件的元素,可以提高查找效率。
  3. 去重处理:在遍历过程中,通过比较当前元素与前一个元素是否相同,来避免重复解。

本题通过排序和双指针法,有效地解决了在数组中找到所有独特三元组的问题,使得三数之和为零。排序使得数组有序,从而可以使用双指针法进行高效的查找。同时,通过去重处理,避免了重复解的出现。这种解题思路不仅适用于本题,还可以扩展到其他类似的查找问题中,如四数之和、五数之和等。通过排序和双指针法的结合,可以大大提高查找效率,减少时间复杂度。

相关推荐
крон2 小时前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
zh_xuan3 小时前
c++ 单例模式
开发语言·c++·单例模式
老胖闲聊3 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1183 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
曹勖之4 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?4 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
军训猫猫头4 小时前
96.如何使用C#实现串口发送? C#例子
开发语言·c#
liuyang-neu5 小时前
java内存模型JMM
java·开发语言
利刃大大5 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
喜欢吃燃面5 小时前
C++刷题:日期模拟(1)
c++·学习·算法