亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

【C語言】LeetCode 18 4Sum

2019-11-14 11:09:30
字體:
來源:轉載
供稿:網友

題目:

Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = target? Find all unique quadruplets in the array which gives the sum of target.

Note: The solution set must not contain duplicate quadruplets.

For example, given array S = [1, 0, -1, 0, -2, 2], and target = 0.A solution set is:[  [-1,  0, 0, 1],  [-2, -1, 1, 2],  [-2,  0, 0, 2]]

思路:

采用循環或者遞歸,逐個查找計算總和。

代碼一(函數循環,12ms)

/** * Return an array of arrays of size *returnSize. * Note: The returned array must be malloced, assume caller calls free(). */int** fourSum(int* nums, int numsSize, int target, int* returnSize) {    int flag;    int temp;    int min;    int **output=NULL;    int last1,last2,last3,last4;//用于記錄上一次取值    //用于判斷是否判斷此次取值與上次取值是否相同    int flag1=0;    int flag2=0;    int flag3=0;    int flag4=0;    int sizereturn=0;    //先進行排序    for(int i=0;i<numsSize;i++)    {        min=nums[i];        for(int j=i;j<numsSize;j++)        {            if(min>=nums[j])            {                flag=j;                min=nums[j];            }        }        temp=nums[flag];        nums[flag]=nums[i];        nums[i]=min;    }    for(int i=0;i<numsSize-3;i++)    {        if(flag1&&nums[i]==last1)continue;//改變第一個值時不可與前一個取值相同,否則重復        if(4*nums[i]>target)break;        if((nums[i]+nums[numsSize-1]+nums[numsSize-2]+nums[numsSize-3])<target)continue;        flag2=0;        for(int j=i+1;j<numsSize-2;j++)        {            if(flag2&&nums[j]==last2)continue;//改變第二個值時不可與前一個取值相同,否則重復            if((nums[i]+3*nums[j])>target)break;            //排序之后,最后的值最大,如果加上最后的值仍小于target,則跳過            if((nums[i]+nums[j]+nums[numsSize-2]+nums[numsSize-1])<target)continue;            flag3=0;            for(int k=j+1;k<numsSize-1;k++)            {                if(flag3&&nums[k]==last3)continue;//改變第三個值時不可與前一個取值相同,否則重復                if((nums[i]+nums[j]+nums[k]+nums[k])>target)break;                if((nums[i]+nums[j]+nums[k]+nums[numsSize-1])<target)continue;                flag4=0;                for(int m=k+1;m<numsSize;m++)                {                    if(flag4&&nums[m]==last4)continue;                    if(nums[i]+nums[j]+nums[k]+nums[m]==target)                    {                        sizereturn++;                        output=(int**)realloc(output,sizereturn*sizeof(int*));                        *(output+sizereturn-1)=(int*)malloc(4*sizeof(int));                        output[sizereturn-1][0]=nums[i];                        output[sizereturn-1][1]=nums[j];                        output[sizereturn-1][2]=nums[k];                        output[sizereturn-1][3]=nums[m];                    }                    else if((nums[i]+nums[j]+nums[k]+nums[m])>target)break;                    flag4=1;                    last4=nums[m];                }                flag3=1;                last3=nums[k];            }            flag2=1;            last2=nums[j];        }        flag1=1;        last1=nums[i];    }    *returnSize=sizereturn;    return output;}

代碼二(遞歸函數,19ms)

/** * Return an array of arrays of size *returnSize. * Note: The returned array must be malloced, assume caller calls free(). */void findtarget(int* nums, int numsSize, int target,int output[],int index,int n,int ***returnarr,int *returnSize){    int flag=0;    int last;    if(n==1)    {        for(int i=index;i<numsSize-n+1;i++)        {            if(flag&&last==nums[i])continue;            if(-1*nums[i]+target==0)            {                (*returnSize)++;                output[n-1]=nums[i];                *returnarr=(int**)realloc(*returnarr,(*returnSize)*sizeof(int*));                *(*returnarr+(*returnSize)-1)=(int*)malloc(4*sizeof(int));                for(int j=0;j<4;j++)                {                    (*returnarr)[*returnSize-1][j]=output[3-j];                }            }            last=nums[i];            flag=1;        }    }    else    {        for(int i=index;i<numsSize-n+1;i++)        {            int sum=nums[i];            int sum2;            if(flag&&last==nums[i])continue;            output[n-1]=nums[i];            for(int si=numsSize-1;si>(numsSize-n);si--)                sum+=nums[si];            sum2=n*nums[i];            if(sum2>target)break;            if(sum<target)continue;            findtarget(nums,numsSize,target-nums[i],output,i+1,n-1,returnarr,returnSize);            last=nums[i];            flag=1;        }    }}int** fourSum(int* nums, int numsSize, int target, int* returnSize) {    int output[4];    int **returnarr=NULL;    int num=0;    int flag=0;    int last;    int min;    int minflag;    int temp;    *returnSize=0;    for(int i=0;i<numsSize;i++)    {        min=nums[i];        for(int j=i;j<numsSize;j++)        {            if(min>=nums[j])            {                minflag=j;                min=nums[j];            }        }        temp=nums[minflag];        nums[minflag]=nums[i];        nums[i]=min;    }    findtarget(nums,numsSize,target,output,0,4,&returnarr,returnSize);    return returnarr;}

思路拓展:

采用遞歸函數稍加修改可適用于K-SUM問題
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久在线观看| 亚洲欧美日韩国产中文| 久久的精品视频| 国产性色av一区二区| 精品二区三区线观看| 久久天天躁狠狠躁老女人| 亚洲国产精品嫩草影院久久| 精品电影在线观看| 国产精品久久久久久av福利软件| 国产视频精品久久久| 欧美中文在线观看| 亚洲精品国产综合区久久久久久久| 亚洲激情视频在线播放| 国产97免费视| 久久精品久久久久久| 欧日韩不卡在线视频| 欧美性20hd另类| 国产精品99久久久久久久久久久久| 91牛牛免费视频| 国产美女精品视频| 亚洲欧美激情在线视频| 国产日韩精品电影| 国产成人在线一区二区| 日韩电视剧在线观看免费网站| 亚洲第一男人天堂| 国产一区二区黑人欧美xxxx| 欧美精品激情在线观看| 黄色91在线观看| 精品国产一区二区三区四区在线观看| 日韩高清不卡av| 欧美性猛xxx| 日韩网站免费观看| 日韩免费av一区二区| 日本亚洲精品在线观看| 亚洲国产精品一区二区三区| 久久精品视频免费播放| 最好看的2019年中文视频| 亚洲欧美在线播放| 在线性视频日韩欧美| 欧美成年人视频网站欧美| 国产99视频精品免视看7| 欧美大肥婆大肥bbbbb| 国产综合福利在线| 亚洲欧美日韩国产中文| 97色在线视频| 精品久久久精品| 亚洲美腿欧美激情另类| 6080yy精品一区二区三区| 一个色综合导航| 久久午夜a级毛片| 欧美激情免费看| 久久久久国产精品免费| 久久精品男人天堂| 成人欧美一区二区三区黑人孕妇| 精品国产一区二区三区四区在线观看| 久久久影视精品| 97成人超碰免| 日韩午夜在线视频| 日韩av男人的天堂| 精品亚洲一区二区三区在线播放| 欧美亚洲在线播放| 久久久久久久久久久人体| 少妇高潮久久77777| 日韩成人在线电影网| 国产经典一区二区| 日韩免费av片在线观看| 日本精品一区二区三区在线| 成人欧美一区二区三区在线| 色综合视频一区中文字幕| 欧美精品激情在线| 中文字幕日本欧美| 91日本在线观看| 欧美理论电影网| 久久夜色精品国产| 欧美激情久久久| 久久久久久亚洲精品中文字幕| 国产视频自拍一区| 亚洲精品久久久久久久久久久久久| 97视频免费看| 91sa在线看| 在线电影av不卡网址| 永久免费精品影视网站| 永久555www成人免费| 亚洲精品乱码久久久久久按摩观| 在线观看日韩av| 亚洲最大在线视频| 久久精品一本久久99精品| 日韩在线国产精品| 91成人福利在线| 欧美日韩精品中文字幕| 欧美亚洲另类制服自拍| 国产精品丝袜一区二区三区| 91美女福利视频高清| 亚洲国产美女精品久久久久∴| 欧美激情视频免费观看| 久久69精品久久久久久国产越南| 日韩美女视频免费在线观看| 国产有码一区二区| 日本sm极度另类视频| 欧美激情一区二区三区久久久| 欧美一级成年大片在线观看| 高跟丝袜欧美一区| 亚洲国产精品va在线| 精品丝袜一区二区三区| 91精品成人久久| 精品国产欧美成人夜夜嗨| 亚洲最大的成人网| 91精品视频播放| 欧美在线免费视频| 欧美猛交ⅹxxx乱大交视频| 欧美在线视频a| 狠狠久久五月精品中文字幕| 欧美电影免费在线观看| 欧美午夜精品久久久久久久| 日韩欧美成人精品| 九九热99久久久国产盗摄| 日本视频久久久| 欧美中文字幕在线视频| 亚洲国产天堂久久综合网| 欧美久久精品午夜青青大伊人| 午夜精品久久久久久久白皮肤| 中日韩午夜理伦电影免费| 久久久精品一区二区| 午夜精品蜜臀一区二区三区免费| 青草青草久热精品视频在线观看| 久久久在线免费观看| 51精品国产黑色丝袜高跟鞋| 欧美性视频在线| 国产精品激情av电影在线观看| 精品偷拍一区二区三区在线看| 日韩大陆欧美高清视频区| 亚洲国产婷婷香蕉久久久久久| 亚洲精品动漫100p| 国产精品jvid在线观看蜜臀| 久久久久久久久久国产| 久久久国产精品一区| 91精品国产综合久久香蕉| 日韩av电影中文字幕| 国产精品久久久久久久久久小说| 亚洲三级 欧美三级| 国产精品自产拍高潮在线观看| 日韩精品中文字幕视频在线| 91情侣偷在线精品国产| 亚洲娇小xxxx欧美娇小| 2023亚洲男人天堂| 欧美乱大交xxxxx| 亚洲一区二区日本| 亚洲精品一区二区三区婷婷月| 欧美老妇交乱视频| 精品国产区一区二区三区在线观看| 亚洲国产另类久久精品| 夜夜嗨av色综合久久久综合网| 亚洲午夜色婷婷在线| 国产精品揄拍一区二区| 成人综合国产精品| 日韩电影大全免费观看2023年上| 亚洲影院色在线观看免费| 国产成人涩涩涩视频在线观看| 欧美插天视频在线播放| 国产美女91呻吟求| 久久午夜a级毛片| 亚洲欧美国产一区二区三区| 欧美日韩国产中文精品字幕自在自线| 一本色道久久综合狠狠躁篇的优点|