国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 學院 > 開發(fā)設計 > 正文

【C語言】LeetCode 18 4Sum

2019-11-14 12:02:18
字體:
來源:轉載
供稿:網友

題目:

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]]

思路:

采用循環(huán)或者遞歸,逐個查找計算總和。

代碼一(函數循環(huán),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問題
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产三区四区在线观看| 日韩黄色成人| 青草在线视频在线观看| jlzzjlzz欧美大全| 不卡av免费观看| 日韩黄色成人| 国产一二区视频| 91三级在线| 欧美高清xxxx性| 国产日本视频| 不卡av免费观看| 狠狠狠狠狠狠操| 国产成人亚洲欧美电影| 日日夜夜中文字幕| 国产激情网址| 国产免费福利| 热99re久久精品这里都是免费| 国产精品天堂| 国产在线观看色| 亚洲va国产日韩欧美精品色婷婷| 久久er视频| 国产91久久久久| 五月婷婷开心综合| 日本国产在线| 中文字幕av在线播放| 国产在线超碰| 亚洲电影视频在线| 国产福利电影在线| 国产卡二和卡三的视频| 日本视频三区| 91视频黄色| 国产精品伦一区二区三区级视频频| www.毛片| 小说区乱图片区| av天天在线| 怡红院av在线| 在线一区观看| av二区三区| av在线播放av| 亚洲精品乱码电影在线观看| 在线免费观看污| 国产三级在线播放| 国产性一级片| 天堂在线一二区 | 在线观看电影av| 国产国产人免费人成免费视频 | 九色视频网站| 国产免费黄网站| 最近中文字幕在线中文视频| 国产网红在线| 91亚洲欧美| av中文在线资源| 狠狠狠狠狠狠操| 国产毛片在线看| 国产国产人免费人成免费视频| 2021天堂中文幕一二区在线观| 精品国产高清a毛片无毒不卡 | 在线久久视频| av人人综合网| 九九热视频精品在线观看| 麻豆国产在线播放| 国产美女性感在线观看懂色av| 1区不卡电影| 国产精品va在线观看视色| 91青青在线视频| 日韩黄色成人| 国产视频xxxx| 日本啊v在线| 国产黄色免费网站| 免费a级人成a大片在线观看| 国产天堂av| 超碰国产在线| 在线观看中文字幕| 国产三级在线播放| 九九视频精品在线| 在线国产三级| 国产欧美日韩专区| 九九视频九九热| 91亚洲天堂| 中文字幕国产视频| 超碰人人在线| 天天草天天干| 中文字幕2019第三页| 国产精品一区二区婷婷| 日本亚洲欧美| 在线观看的网站你懂的| 国产精品18久久久久久久久久| 丁香综合在线| 黄色一级视频网站| www在线观看播放免费视频日本| 国产精品视频h| 成在在线免费视频| 久草视频国产| 欧美精品一区二区三区免费| 国产欧美日韩专区| 国产一区二区影视| 国产网站在线免费观看| 丁香视频免费观看| 高清av在线| 国产精品午夜久久久久久| 国产综合视频一区二区三区免费| 美女网站在线观看| 国产精选在线视频拍拍拍| 国产精品自拍在线观看| 最新av免费看| 在线天堂中文www视软件| 中文字幕av高清| 亚洲大香人伊一本线| 在线观看精品一区二区三区| 在线午夜影院| 白浆爆出在线观看| 久久国产热视频| 国产深夜福利| 在线免费看av| 高潮白浆视频| 国产91在线视频蝌蚪| 亚洲v片在线观看| 国产免费视频在线| 91亚洲天堂| 丁香视频五月| 99在线视频观看| 激情五月色综合亚洲小说| 国产精品一区二区三区高清在线| 五月婷婷在线视频| 在线视频三区| 国产网红在线观看| 国产精品xxx电影| 国产va在线| 国产一区二区三区不卡在线| 国产小视频在线观看| 精品偷拍激情视频在线观看| 日本不卡视频一区二区| 国产美女性感在线观看懂色av| 国产精品视频一区二区免费不卡 | 精品推荐国产麻豆剧传媒| 亚洲欧美自拍另类| 最新黄网在线观看| www.操操操| 中文岛国精品亚洲一区| 中文字幕在线影视资源| 亚洲欧美一区二区三区在线播放| 国产丝袜精品丝袜| а√最新版在线天堂| 精品国产二区三区| 日本中文字幕在线视频| 久草网在线视频| 麻豆福利在线观看| 人日人天天爽| 在线中文字幕视频| 99福利在线| 国产叼嘿网站免费观看不用充会员| 久精品在线观看| 超碰在线观看免费| 男女午夜视频在线观看| 日本三级在线视频| 在线观看免费高清完整| 国产不卡视频| 一本大道久久a久久精品| 精品视频一区二区观看| 精品国产一区二区三区久久久狼牙 | gogo在线高清视频| 91这里只有精品| 国产aa视频| 在线视频观看亚洲| 香蕉视频网站在线播放| h网站久久久| 美女网站在线观看| 国产嫩草在线视频| 国产色a在线| 在线观看国产福利视频| www.91av| 青青草原av在线| 国产中文字幕在线| 国产视频第一区| 亚洲人av在线| 丁香花高清在线观看完整版| 国产一级激情| 伊人久久青青草| 久久一本精品| 国产aa视频| 久久精品国产亚洲a∨麻豆| 国产精品天堂| 在线免费看黄av| 中文字幕在线视频免费观看| 91免费日韩| 国产女王在线**视频| 国产va在线| 天天激情综合| 国产一级免费| sese一区| 在线视频中文字幕久| 成人无遮挡免费网站视频在线观看| 国产一区精品| 碰草在线视频| 91在线高清| 国产网站麻豆精品视频| 毛片网站在线观看| 中文天堂av| 国产精品冒白浆免费视频 | gogo在线观看|