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;
}
相关推荐
像少年啦飞驰点、5 小时前
从零开始学 RabbitMQ:小白也能懂的消息队列实战指南
java·spring boot·微服务·消息队列·rabbitmq·异步编程
清水白石0085 小时前
《为什么说 deque 是 Python 滑动窗口的“隐藏神器”?深入解析双端队列的高效之道》
开发语言·python
杜子不疼.5 小时前
Ascend_C自定义算子开发
c语言·开发语言
宠友信息5 小时前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
java1234_小锋5 小时前
Java高频面试题:Spring和SpringBoot的关系和区别?
java·spring boot·spring
风指引着方向5 小时前
昇腾算子性能调优:ops-nn 中的内存布局与向量化技巧
java·大数据·人工智能
WooaiJava5 小时前
流式TTS音频播放项目 - 面试问答(后端)
java·开发语言
奥升新能源平台5 小时前
奥升充电|充电站用户分层分析与精细化运营策略研究
java·大数据·能源
R1nG8635 小时前
CANN资源泄漏检测工具源码深度解读 实战设备内存泄漏排查
数据库·算法·cann
新缸中之脑6 小时前
开发AI代理必备的8个Python 库
开发语言·人工智能·python