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

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

【C語(yǔ)言】LeetCode 18 4Sum

2019-11-14 10:39:33
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

題目:

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)或者遞歸,逐個(gè)查找計(jì)算總和。

代碼一(函數(shù)循環(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;    //先進(jìn)行排序    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;//改變第一個(gè)值時(shí)不可與前一個(gè)取值相同,否則重復(fù)        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;//改變第二個(gè)值時(shí)不可與前一個(gè)取值相同,否則重復(fù)            if((nums[i]+3*nums[j])>target)break;            //排序之后,最后的值最大,如果加上最后的值仍小于target,則跳過(guò)            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;//改變第三個(gè)值時(shí)不可與前一個(gè)取值相同,否則重復(fù)                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;}

代碼二(遞歸函數(shù),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;}

思路拓展:

采用遞歸函數(shù)稍加修改可適用于K-SUM問(wèn)題
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产精品一线天粉嫩av| 日韩av影院在线观看| 精品国产欧美日韩不卡在线观看| 欧美另类videos| 日韩福利一区| 欧美三级超在线视频| 中文精品一区二区三区| 久久久久久国产视频| 午夜精品一区二区三区国产| 美国一区二区三区在线播放| 免费黄色地址| 一级黄色a视频| 91麻豆国产语对白在线观看| 欧美肥老太太性生活| 三级av在线| 91精品国产91久久久久久最新| 亚洲小说区图片区情欲小说| 精品久久中文字幕久久av| 精品久久久久久综合日本欧美| 在线观看视频在线观看| 免费一看一级毛片| 久久资源免费视频| 国产精品一二二区| 操操操综合网| 午夜欧美视频在线观看| 小草在线视频在线免费视频| 欧美大片在线影院| 二区在线播放| 人人草人人干| 美腿丝袜亚洲一区| 国产精品免费观看| 亚洲最好看的视频| 特级黄国产片一级视频播放| 久久亚洲av午夜福利精品一区| 欧美性猛交xxxx黑人猛交| 丝袜美女写真福利视频| 99免在线观看免费视频高清| 欧美裸体bbwbbwbbw| 一区二区三区加勒比av| 久久久久久久久久亚洲| 日韩成人免费在线视频| 国产免费黄色网址| 亚洲欧美日韩一区二区三区在线| 国产一级视频在线观看| 国产一级二级三级| 久久综合久久综合这里只有精品| 中文字幕一区二区三区人妻在线视频| 久久久精品国产一区二区| 亚洲女优在线观看| 午夜国产福利| 二区三区四区视频| 亚洲福利国产| 99精品视频在线免费播放| 久久最新网址| 黄网页在线观看| 男人午夜天堂| 91视频在线免费观看| 日韩精品一区二区在线| 都市激情久久综合| 国产偷倩在线播放| 成人免费观看在线| 亚洲精品一区二区三区四区五区| 精品高清在线| 中文字幕中文字幕在线十八区| 日韩精品一页| 成年人在线播放| 国产午夜久久av| 欧美另类69xxxx| 亚洲美女性生活| 精品人妻伦一二三区久| 中日韩黄色大片| 毛片不卡一区二区| 国产精品一区二区黑人巨大| 久久一级免费视频| 欧美美女bb生活片| 国内精品久久久久影院 日本资源| 欧美成人app| 黑料不打烊so导航| 无圣光视频在线观看| 成人在线视频一区二区三区| 91动漫免费网站| 亚洲av成人无码久久精品老人| 99国产精品久| 亚洲欧美天堂| 一级片免费在线播放| 国产亚洲美女久久| 欧美一级片免费在线观看| 久久国产劲爆∧v内射| 欧美日韩亚洲精品内裤| 日韩在线视频观看正片免费网站| 国产强被迫伦姧在线观看无码| 激情 小说 亚洲 图片: 伦| 91精品国产欧美日韩| 国产91在线播放九色快色| 久久久久久久久久久久久久免费看| 999成人网| 欧美精品久久久久久久久久丰满| 中文在线字幕av| 黄色av网址在线| 色鬼7777久久| 少妇精品视频一区二区| 最近最新中文字幕在线| 国产h视频在线播放| 激情小说中文字幕| 欧洲美熟女乱又伦| 俄罗斯嫩小性bbwbbw| 西西44rtwww国产精品| 一区二区三区入口| 亚洲无码精品在线播放| 国产第100页| 网站一区二区| 久久综合中文字幕| 欧美精品二区| av成人app永久免费| 欧美aaa级片| 日韩中字在线观看| 国产精品一区二区三区观看| 久久久精品蜜桃| 精品裸体舞一区二区三区| 亚洲第一二三四区| 在线国产一区二区三区| 亚洲午夜精品久久久久久人妖| 日本特黄a级片| 香蕉影院在线观看| 福利h视频在线| 一区二区三区四区在线播放| 欧美一级二区| 亚洲精品动态| 国产精品久久久久久久久快鸭| 在线精品国产成人综合| 色综合久久88色综合天天免费| 国产精品高清乱码在线观看| 亚洲理论片在线观看| 日日爱夜夜操| 隣の若妻さん波多野结衣| 在线免费观看黄色av| 久久久久久亚洲精品不卡| 在线看无码的免费网站| 欧美激情一区在线观看| 中文字幕日本人妻久久久免费| 亚洲毛片欧洲毛片国产一品色| 大胆av不用播放器在线播放| 日本免费一区二区三区视频观看| 最新中文在线视频| 精品国产一区二区三| 春意影院午夜免费入口| 老司机在线永久免费观看| 午夜亚洲精品| 久久久久蜜桃| 欧美午夜宅男影院| 日本久久一区二区三区| 国产h色视频在线观看| av激情在线观看| 精品国产黄a∨片高清在线| 欧美日本在线视频中文字字幕| 日韩视频一区二区| 天堂中文在线观看视频| 黄色网址中文字幕| av免费在线观看网址| 欧美一区欧美二区| 朝桐光av在线一区二区三区| 人人超碰在线| 自拍视频第一页| jizz欧美大全| 翔田千里亚洲一二三区| 一级片视频网站| 欧美激情一区二区三区在线视频| 亚洲成人动漫精品| 国产一区二区毛片| 国产免费无遮挡吸奶头视频| 91在线国产剧情| 日韩精品无码一区二区三区久久久| 国产高清久久久| 久久久久欧美精品| 性视频一区二区三区| 日韩成人在线视频| 男生女生差差差的视频在线观看| 天天爽夜夜爽视频| 国产女女做受ⅹxx高潮| 国产人成网在线播放va免费| 国产精品久久久久久久9999| 欧美电影网址| 久久品道一品道久久精品| 交换国产精品视频一区| 色婷婷综合久久久久久| 日本一二三视频| 婷婷综合福利| 国产1区二区| 福利网站在线观看| 91精品国产综合久久久蜜臀九色| 91在线三级| 成人亚洲免费视频| 一区二区三区在线免费| 亚洲**2019国产| 欧美精品videossex性护士| 91精品观看| 天堂а在线中文在线无限看推荐| 麻豆视频免费网站| 精品人体无码一区二区三区| 成人国内精品久久久久一区| 品久久久久久久久久96高清| 亚洲免费av网站| 麻豆精品av| 成人网18免费软件大全| 中文字幕国产高清| 亚洲综合激情另类小说区| 成年人在线观看网站| 久久久久久这里只有精品| 毛片av一区二区三区| 香蕉加勒比综合久久| 国内在线高清免费视频| 久久久影院免费| 色91精品久久久久久久久| 性生活视频网址| 女人在下体塞跳蛋在线观看| 欧美日韩伦理| 国产精品视频yy9099| 亚洲高清免费视频| 国产草草影院ccyycom| 亚洲中文字幕无码中文字| brazzers欧美精品| www..com.cn蕾丝视频在线观看免费版| 日韩高清在线一区| 欧美日韩中文字幕视频| 亚洲日本一区二区三区| 日韩欧美中文字幕电影| 久久综合伊人77777蜜臀| 久久亚洲电影| 宅男在线观看免费高清网站| 欧美午夜精品在线| 国产欧美日韩精品高清二区综合区| 污片在线免费看| 欧美日本久久| 国产精品一香蕉国产线看观看| 日韩欧美在线观看免费| 亚洲 国产 欧美 日韩| 老牛影视av牛牛影视av| 国产成人亚洲综合91| 中国黄色在线视频| 久久久久久久国产精品影院| 亚洲一区二区不卡视频| 日韩永久免费视频| 亚洲欧洲在线看| 77777影视视频在线观看| 国产精品二区一区二区aⅴ污介绍| 日本黄色三级视频| 成r视频免费观看在线播放| 激情av综合网| 欧美视频一区二区在线观看| 激情校园亚洲图片| www.成人在线| 国产一区二区三区探花| 国产美女精品人人做人人爽| 日韩丝袜美女视频| 五月天丁香激情| 欧美视频在线免费看| 中文字幕第22页| 日韩黄色在线视频| 91精品国产品国语在线不卡| 视频一区二区三区免费观看| 色综合一个色综合亚洲| 操你啦在线视频| 综合久草视频| 中文字幕中文字幕| 亚洲国产高清aⅴ视频| 黄网站视频在线观看| 免费在线观看a| 久久亚洲精品中文字幕蜜潮电影| av免费在线播放网站| 91av在线播放| 日韩福利视频网| 99精品视频在线| 2019国产精品自在线拍国产不卡| 亚洲精品97| 亚洲a一区二区三区| 无码人妻aⅴ一区二区三区| 黄色一级视频免费看| 韩国中文字幕在线| 97久久精品人人做人人爽50路| 亚洲黄色有码视频| 国产在线观看18| 欧美日韩国产观看视频| 99在线精品免费视频九九视| 一区二区三区在线观看www| 国产免费不卡| 99国内精品久久久久久久软件| 精品午夜久久| av资源在线免费观看| 欧美a极品极品欧美| 中日韩av电影| 成人在线免费看黄| 免费成人在线电影| 欧美另类色图| 51国产成人精品午夜福中文下载| 94色蜜桃网一区二区三区| 亚洲理论电影片| а 天堂 在线| 久久av一区二区三区亚洲| 亚洲免费影视| 国产高潮免费视频| 亚洲大片免费看| 日韩福利视频在线观看| 快色在线观看| 久久久久久久久久久久久久久久久久av| 久草在线资源视频| 91理论片午午论夜理片久久| 国产噜噜噜噜噜久久久久久久久| 欧美三级小说| h版电影在线播放视频网站| 久久久久久久一区二区三区| 色综合久久久久久中文网| 激情影院在线| 亚洲一区二区高清视频| 亚洲人成在线影院| 丝袜美腿av在线| 国产激情视频一区二区三区| 欧美日韩看片| 麻豆久久久久| 日韩欧美精品| 久久精品九色| 最近2019中文字幕mv免费看| 国内精品免费一区二区三区| 成人直播大秀| 秋霞网一区二区三区| 精品福利视频导航大全| 国产综合婷婷| 在线观看视频免费一区二区三区| 3d黄动漫网站|