【LeetCode刷题(数据结构与算法)】:三数之和(数组+指针+排序)

news2025/1/11 21:45:45

在这里插入图片描述
给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 请你返回所有和为 0 且不重复的三元组
注意:答案中不可以包含重复的三元组
示例 1:
输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0
不同的三元组是 [-1,0,1] 和 [-1,-1,2]
注意,输出的顺序和三元组的顺序并不重要
示例 2:
输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0
示例 3:
输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0
代码和思路都写在下面了

/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */
int cmp(const void *a,const void *b)
{
    return (*(int*)a-*(int*)b);
}
int** threeSum(int* nums, int numsSize, int* returnSize, int** returnColumnSizes){
    //初始空间 因为不知道一维数组的实际空间大小
    int basement=10000;
    //开辟一个二维数组用于存放一维数组以便计算sum是否为0且i j k不重复
    int**res=(int**)malloc(sizeof(int*)*basement);
    //升序排序
    *returnColumnSizes=(int*)malloc(sizeof(int)*basement);
    *returnSize=0;
    qsort(nums,numsSize,sizeof(int),cmp);
    int i=0;int j=0;int k=0;
    for(i=0;i<numsSize;i++)
    {
        if(i>0&&nums[i]==nums[i-1])
            continue;
    j=i+1;
    k=numsSize-1;
    while(j<k)//升序数组 如果大于k就跳出循环
    {
        int sum=nums[i]+nums[j]+nums[k];
        if(sum==0)
        {
            res[*returnSize]=(int*)malloc(sizeof(int)*3);
            (*returnColumnSizes)[*returnSize]=3;
            res[*returnSize][0]=nums[i];
            res[*returnSize][1]=nums[j];
            res[*returnSize][2]=nums[k];
            (*returnSize)++;

        //二维数组存放数据
        //那个returnColumnSizes是用来干嘛的我不清楚
    //然后就是由于一维数组大小不确定 可能有越界的情况
    //realloc一个空间 增大二维数组的空间
    if(*returnSize==basement){
        basement*=2;
        res=(int**)realloc(res,sizeof(int*)*basement*2);
        *returnColumnSizes=(int*)realloc(*returnColumnSizes,sizeof(int)*basement);
    }
    //题目要求去除重复元素
    int nums1=nums[j];int nums2=nums[k];
        while(nums[j]==nums1&&j<k)
        {
            j++;
        }
        while(nums[k]==nums2&&j<k)
        {
            k--;
        }
        }
    //当sum三数之和小于0时 j往右移动再找
        else if(sum<0){
            j++;
        }
    //当sum三数之和大于0时 k往左移动再找
        else{
            k--;
        }
    //然后当sum<0的时候 j往后移动++ 因为升序
    //else k往前移动--
        }
    }
    return res;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1128142.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

51单片机的hello world之点灯

文章目录 前言一、基础定义和点灯二、延时函数三、独立按键三、中断的配置和使用外部中断法捕获中断 总结 前言 hello 大家好这里是夏目学长的51单片机课堂&#xff0c;本篇博客是夏目学长观看B站up主学电超人的视频所写的一篇51单片机入门博客之51单片机点灯以及 独立按键 中…

Fiddler 的使用(详细教程)

文章目录 前言一、简介二、下载安装三、界面简介1. 菜单栏2. 工具栏3. 会话面板4. 辅助标签工具5. 命令行6. 状态栏 四、常用功能1. 抓取指定 IP 地址的包2. 抓取 HTTPS 协议的包3. 手机 APP 抓包4. 发送序列化请求5. 发送上传文件请求 五、常见问题 前言 Fiddler 是最常用的 …

成都优优聚美团代运营:助力商家腾飞的隐形翅膀

在当前数字化时代&#xff0c;电子商务的飞速发展使得线上运营成为越来越多商家的必然选择。在这个过程中&#xff0c;美团代运营作为一种专业的外包服务模式&#xff0c;正逐渐发挥出其巨大的作用。 一、美团代运营的定义与作用 美团代运营&#xff0c;顾名思义&#xff0c;是…

TikTok网红营销:挖掘潜在客户的高效策略

在当今数字时代&#xff0c;社交媒体已经成为了企业吸引潜在客户的重要渠道之一。TikTok作为全球范围内最热门的短视频分享平台之一&#xff0c;为企业提供了一个独特的机会&#xff0c;可以通过网红营销来挖掘潜在客户。本文Nox聚星将和大家探讨如何在TikTok上运用网红营销策略…

大数据时代,网络安全人员的钱途在哪里?

未来10年20年以后&#xff0c;这世界最珍贵的资源、最稀缺的资源&#xff0c;不会是石油&#xff0c;一定是数据。企业要有最快获取数据的能力、处理数据的能力、分享数据的能力、产生数据的能力。在刚过去不久的2020中国国际智能产业博览会上&#xff0c;马云在8分钟演讲里30次…

提取机器人专注视频号视频下载!视频号视频下载使用教程

知道吗&#xff1f;原来我们可以轻松地将视频下载到手机上&#xff0c;无需再繁琐操作了&#xff01;那么&#xff0c;让我教你一招吧&#xff01; 首先&#xff0c;你需要一个神器——名字叫做「提取机器人」。这个小众冷门的应用真的是保姆级存在&#xff0c;让你的下载经验变…

CI/CD:GitLab-CI 自动化集成/部署 JAVA微服务的应用合集

CI/CD&#xff1a;GitLab-CI 自动化集成/部署 JAVA微服务的应用合集 CI/CD&#xff1a;GitLab-CI 自动化集成/部署 JAVA微服务的应用合集安装DockerGitLabGitLab-Runner阿里云容器仓库 GitLab-CIJava微服务的GitLab-CI应用 CI/CD&#xff1a;GitLab-CI 自动化集成/部署 JAVA微服…

Zabbix自定义监控项监控进程状态

agent服务端配置 自定义监控项脚本 # 文件路径: C:\zabbix_agent2-6.0.4-windows-amd64-static\conf\a.bat echo off setlocalset "processNameo2Popper.exe"tasklist /FI "IMAGENAME eq %processName%" 2>NUL | find /I /N "%processName%"…

微信小程序抓包及测试

目录 环境准备 小程序反编译 一不小心getshell 本来只想写个抓包反编译过程&#xff0c;没想到大肠包小肠有意外收获 网上大多数的小程序测试抓包都是用的安卓模拟器&#xff0c;这里使用的是BurpSuiteProxifer微信客户端的抓包方式 环境准备 Burp2023.9.2 Proxifier4.5…

darknet框架 训练分类模型及测试图片

darknet 框架的Yolo模型大概已经没什么公司使用了&#xff0c;对于老项目的维护可能新手需要了解下&#xff0c;然而 darknet架构并不十分友好&#xff0c;新手入手门槛比较高&#xff0c;特别是做分类任务时&#xff0c;简直了&#xff01;&#xff01;&#xff01; 博主也是走…

交传翻译在不同场合的差异,你了解多少?

交替传译就是指译员在讲话人发言后&#xff0c;将目标语言准确翻译出来的口译方式。两会期间的新闻发布会就是采用交传。与同传相比&#xff0c;交传更具挑战性&#xff0c;因为译员需要承受与听众直接交流的压力&#xff0c;同时也需要充分理解源语言的内容并进行适当的结构调…

日志报错 fork:Cannot allocate memory

现象描述 日志中出现报错信息 “fork&#xff1a;Cannot allocate memory”。如下图所示&#xff1a; 可能原因 可能是进程数超限导致。系统内部的总进程数达到了 pid_max 时&#xff0c;再创建新进程时会报 “fork&#xff1a;Cannot allocate memory” 错。 解决思路 1. …

有效防止重要需求遗漏的几点建议

防止重要需求的遗漏&#xff0c;保障需求的完整性&#xff0c;这直接关系着项目的成功和客户的满意度。如果关键需求被遗漏或忽视&#xff0c;项目可能无法达到预期的目标和交付成果&#xff0c;无法满足用户的需求和期望&#xff0c;直接影响产品的市场竞争力。 因此确保需求的…

哪吒X选车指南:推荐哪吒X 500lite 版

当下,紧凑型纯电动SUV市场新车不断,可选项越来越多。最近哪吒汽车又上市一款“大气舒适新标杆”——哪吒X,限时权益价10.88万元-12.88万元,以大空间,超舒适,更安全等优势,强势对标AION Y Plus和元Plus等车型。 很多有购车打算的消费者看过价格和配置,直呼哪吒X是“性价比显眼包…

【linux】SourceForge 开源软件开发平台和仓库

在linux上面安装服务和工具。我们经常会下载安装包。今天推荐一个网站。 SourceForge 开源软件开发平台和仓库 ​ 全球最大开源软件开发平台和仓库 SourceForge.net&#xff0c;又称SF.net&#xff0c;是开源软件开发者进行开发管理的集中式场所。 SourceForge.net由VA Softwa…

JavaScript_Pig Game摇骰子

对于一个大的项目&#xff0c;画流程图是一种特别好的方式&#xff01; ● 我们首先把页面上的重置游戏、掷色子、切换用户存入变量中 const btnNew document.querySelector(.btn--new); const btnRoll document.querySelector(.btn--roll); const btnHold document.quer…

GoLong的学习之路(八)语法之Map

文章目录 Map初始化方式判断某个键是否存在map的遍历对value值遍历。对key值遍历 使用delete()函数删除键值对按照指定顺序遍历map元素为map的切片值为切片类型的map 做个题吧 Map 哈希表是一种巧妙并且实用的数据结构。它是一个无序的key/value对的集合&#xff0c;其中所有的…

Day 10 python学习笔记

高阶函数 map( ) map()函数接收两个参数&#xff0c;一个是函数&#xff0c;一个是Iterable&#xff0c;map将传入的函数依次作用到序列的每个元素&#xff0c;并把结果作为新的Iterator返回。&#xff08;Iterator是一个可迭代对象&#xff09; 再简单点说&#xff1a;从可迭代…

跨境电商的发展趋势及语言翻译的重要性

随着全球化的不断深入和互联网技术的普及&#xff0c;跨境电商在过去几年内得到了快速发展。跨境电商指的是企业通过电子商务平台销售商品或服务给其他国家或地区的消费者。这种模式不仅打破了传统国际贸易的限制&#xff0c;也为企业提供了更广阔的市场空间。 跨境电商的快速发…

音视频技术开发周刊 | 316

每周一期&#xff0c;纵览音视频技术领域的干货。 新闻投稿&#xff1a;contributelivevideostack.com。 日程揭晓&#xff01;速览深圳站大会专题议程详解 LiveVideoStackCon 2023 音视频技术大会深圳站&#xff0c;保持着往届强大的讲师阵容以及高水准的演讲质量。两天的参会…