LeetCode18四数之和

代码来源:代码随想录

c 复制代码
/**
 * 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 compare(const void *a,const void *b)
{
    int a1=*(int *)a;
    int b1=*(int *)b;
    return (a1>b1)-(a1<b1);
}
int** fourSum(int* nums, int numsSize, int target, int* returnSize, int** returnColumnSizes)
{
    //1.对数组进行排序
    qsort(nums,numsSize,sizeof(int),compare);
    //2.分配空间,解的数量上限是C(200 4),但经验值为40000,避免过度分配内存
    int **result=(int **)malloc(sizeof(int *)*40000);
    int count=0;//计数器,记录解的数量
    for(int i=0;i<numsSize-3;i++)
    {
        /* 剪枝:如果nums[i]已经大于target且为正数,后面不可能有解 */
        if ((nums[i] > target) && (nums[i] >= 0)) {
            break;
        }
        /* 去重:跳过重复的nums[i] */
        if ((i > 0) && (nums[i] == nums[i - 1])) {
            continue;
        }
        for(int j=i+1;j<numsSize-2;j++)
        {
            /* 剪枝:如果前两数之和已经大于target且nums[j]为正数 */
            if ((nums[i] + nums[j] > target) && (nums[j] >= 0)) {
                break;
            }
            /* 去重:跳过重复的nums[i] */
            if ((j > (i + 1)) && (nums[j] == nums[j - 1])) {
                continue;
            }
            //左指针
            int left=j+1;
            //右指针
            int right=numsSize-1;
            while(left<right)
            {
                long long sum=(long long)nums[i]+nums[j]+nums[left]+nums[right];
                if(sum>target)
                {
                    right--;
                }
                else if(sum<target)
                {
                    left++;
                }
                else
                {
                    //3.找到符合条件的四元组记录到result中
                    int *result_tmp=(int *)malloc(sizeof(int)*4);
                    result_tmp[0]=nums[i];
                    result_tmp[1]=nums[j];
                    result_tmp[2]=nums[left];
                    result_tmp[3]=nums[right];
                    result[count++]=result_tmp;
                    //去重,去掉重复的left和right
                    while ((right > left) && (nums[right] == nums[right - 1])) {
                        right--;
                    }
                    while ((left < right) && (nums[left] == nums[left + 1])) {
                        left++;
                    }
                    right--;
                    left++;
                }
            }
        }
    }
    *returnSize=count;
    int *column=(int *)malloc(sizeof(int)*count);
    for(int i=0;i<count;i++)
    {
        column[i]=4;
    }
    *returnColumnSizes=column;
    return result;
}
相关推荐
寒山李白15 分钟前
JavaSE核心知识点01基础语法01-04(数组)
java·学习·数组
Java~~19 分钟前
山东大学软件学院项目实训-基于大模型的模拟面试系统-个人主页头像上传
java·vue.js·spring
Auc2421 分钟前
基于Redis实现优惠券秒杀——第3期(分布式锁-Redisson)
java·数据库·redis·分布式·缓存·redisson
Echo``1 小时前
25:三大分类器原理
图像处理·人工智能·算法·机器学习·支持向量机·计算机视觉·视觉检测
pound1271 小时前
第十章.XML
xml·java·前端·javascript
学习2年半1 小时前
groups 属性分组
java·jvm·数据库
LuckyRich11 小时前
【JsonCpp、Muduo、C++11】JsonCpp库、Muduo库、C++11异步操作
开发语言·c++
钢铁男儿2 小时前
C# 方法的结构与执行详解
开发语言·c#
佩奇的技术笔记2 小时前
Java学习手册:Spring 生态其他组件介绍
java·spring
陈庆之的论衡2 小时前
使用 Poco C++ 库构建轻量级 HTTP 服务器
开发语言·c++·http