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

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

【C語言】LeetCode 18 4Sum

2019-11-14 11:06:15
字體:
供稿:網(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)或者遞歸,逐個查找計算總和。

代碼一(函數(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;    //先進行排序    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;//改變第一個值時不可與前一個取值相同,否則重復(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;//改變第二個值時不可與前一個取值相同,否則重復(fù)            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;//改變第三個值時不可與前一個取值相同,否則重復(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問題
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
午夜在线视频一区二区区别| 欧美激情在线观看| 成年人黄视频网站| 国产叼嘿网站免费观看不用充会员| 男人舔女人下面高潮视频| 久久亚洲精品爱爱| 香蕉久久精品| 色先锋资源网| 亚洲男女视频在线观看| 国产精品一区二区三区免费观看| 蜜臀av一区二区在线观看| 色在线免费视频| 开心九九激情九九欧美日韩精美视频电影| 欧美在线视频一区二区三区| 久久综合精品国产一区二区三区| 欧美日韩国产一中文字不卡| 欧美激情精品久久久久久蜜臀| 香港日本韩国三级网站| 小泽玛利亚一区二区三区视频| 99久久精品免费看国产一区二区三区| 欧美男人天堂网| 污污影院在线观看| 91av在线视频观看| 亚洲蜜桃精久久久久久久| 国产精品一区二区资源| 久久久久久久| 中文岛国精品亚洲一区| 一级做a爰片毛片| 欧美日韩在线视频首页| 亚洲国产精彩中文乱码av在线播放| 日韩精品123区| 日本色护士高潮视频在线观看| 欧洲精品在线视频| 色8久久影院午夜场| av动漫在线观看| free性欧美16hd| 成人影院在线观看视频| 少妇av一区二区三区| 久久久美女视频| 九九九九九九精品任你躁| 日本黄大片一区二区三区| 中文字幕免费在线观看视频| 亚洲欧美成人一区二区三区| 视频一区三区| a级日韩大片| 国产精品免费一区二区| 四虎中文字幕| 香蕉视频在线观看黄| 99久久伊人精品| 亚洲色图狂野欧美| 亚洲图片欧洲图片av| 日韩欧美在线视频一区二区| 91精品国产欧美一区二区成人| 国产白丝袜美女久久久久| 98视频精品全部国产| 三级a三级三级三级a十八发禁止| 成人亚洲精品777777大片| 欧美一级网站| 91传媒免费看| 午夜性色福利视频| 中文字幕人妻无码系列第三区| 国产66精品久久久久999小说| 亚洲成精国产精品女| 欧美高清一区| 精品国内片67194| 狠狠88综合久久久久综合网| 国产69精品99久久久久久宅男| 久久久不卡影院| 这里只有精品免费视频| 4388成人网| 国产av无码专区亚洲av| 亚洲美女精品视频| 亚洲欧美日韩系列| 这里只有精品免费视频| 5566中文字幕一区二区| 在线能看的av网址| 精品日本一区二区三区在线观看| 日本高清+成人网在线观看| 亚洲成人免费在线| 国产二区视频在线| www.浪潮av.com| 少妇特黄a一区二区三区| 欧美综合国产精品久久丁香| 极品久久久久久| 成人av在线看| 亚洲精品成人悠悠色影视| 麻豆成人在线播放| 日韩在线观看一区| av之家在线观看| 欧美大肥婆大肥bbbbb| 在线免费日韩| 素人fc2av清纯18岁| 亚洲精品国产欧美| 91久久电影| 涩涩视频在线观看| аⅴ资源新版在线天堂| 日本又骚又刺激的视频在线观看| 91大神福利视频在线| 一区二区三区导航| 久久99精品国产| 国产三级精品在线观看| 午夜在线视频一区二区区别| 日韩亚洲电影在线| 亚洲大胆av| 久久亚洲国产精品尤物| 三级影片在线观看欧美日韩一区二区| 92裸体在线视频网站| 天堂精品在线视频| 日韩三级影院| 色综合视频网站| 中国av在线播放| 性欧美高清强烈性视频| 国产精彩视频一区二区| 天天舔天天干天天操| 97在线视频精品| 婷婷国产成人久久精品激情| 六月天色婷婷| 中文字幕一区二区久久人妻网站| 色婷婷综合久久久久| 亚洲欧美va天堂人熟伦| 成人黄色免费片| av网站在线观看免费| 真实国产乱子伦精品一区二区三区| 欧美精品videosex性欧美| 色综合五月天| 成人中文字幕在线播放| 国产精品久久中文字幕| 超碰99在线| h短视频大全在线观看| 欧美成人国产一区二区| 给我免费播放片在线观看| 亚洲精品美女网站| 亚洲影院久久精品| 91丨porny丨国产入口| 诱受h嗯啊巨肉高潮| 久久国产电影| 超碰在线cao| 在线中文字幕网站| ass大特写| 四虎影视精品| 色综合久久中文字幕| 狠狠色噜噜狠狠狠狠888奇米| 成人免费一区二区三区| 91精品国产99| 久久久久亚洲AV成人无码国产| 国产精品7m凸凹视频分类| 综合色天天鬼久久鬼色| 欧美日韩生活片| 在线免费日韩av| 欧美多人乱p欧美4p久久| 怡红院精品视频在线观看极品| 97涩在线观看视频| 4kfree性满足欧美hd18| 插菊花综合1| 国产伦精品一区二区三区高清版禁| 91福利资源站| 日韩一区二区三区免费视频| 宅男午夜电影| 日韩一级片播放| 在线观看欧美一区二区| www国产亚洲精品久久网站| 首页国产欧美日韩丝袜| 亚洲人人夜夜澡人人爽| 少妇激情一区二区三区视频| 永久www成人看片| 久久精品电影| 九色91porny| 日韩欧美字幕| 欧美一区二区三区播放| 欧美疯狂做受xxxx高潮| 黄色在线视频网站| 韩日av一区二区| 免费日韩在线观看| 给我免费播放日韩视频| 黄色的电影在线-骚虎影院-骚虎视频| 6—12呦国产精品| 亚洲国产精品传媒在线观看| 黄色在线免费观看| 激情无码人妻又粗又大| 麻豆乱码国产一区二区三区| 激情五月色综合亚洲小说| 国产suv精品一区二区6| 综合久久2o19| 国产欧美日韩成人| 91欧美激情一区二区三区成人| 国产99视频在线观看| 久久精品中文| 91网站免费入口| 欧美777四色影视在线| 狠狠综合久久av一区二区老牛| 国产一二三四五区| a级在线观看视频| 精品综合久久久久久97| 日本不卡高清| 香蕉视频一区| 亚洲av无码国产精品久久| 久久久久久黄| 日韩乱码人妻无码中文字幕| 任你躁av一区二区三区| 26uuu国产精品视频| 国产在线播放91| 国产美女www| 成人免费视频网| 欧美黄色网络| 久草网站在线观看| 一级黄色片在线看| 久久久一本精品99久久精品66| 疯狂蹂躏欧美一区二区精品| va天堂va亚洲va影视| 婷婷精品久久久久久久久久不卡| 四虎海外影库www4hu| 先锋在线亚洲| 小早川怜子久久精品中文字幕| 国产成人综合网站| 成人影音在线| 精品第一国产综合精品aⅴ| 欧美一区日本一区韩国一区| 久久亚洲国产精品一区二区| 91青青草免费在线看| 欧洲精品视频在线| 99国产一区二区三精品乱码| 久久99久久人婷婷精品综合| 中文字幕一区二区三区四区在线视频| 国产欧美一区二区三区另类精品| 欧美日韩免费高清一区色橹橹| 欧美日韩第二页| 川上优的av在线一区二区| 国内精品**久久毛片app| 不卡电影免费在线播放一区| 亚洲va欧美va国产va天堂影院| 波多野结衣av在线| 国产二区国产一区在线观看| 精品国模一区二区三区| 国产精品色在线网站| 久久亚洲综合色一区二区三区| 日本精品入口免费视频| 日韩亚洲欧美中文三级| 久久精品国产第一区二区三区| 成年在线播放小视频| 黄色网在线免费看| 欧美最猛性xxxxx喷水| 日韩一区二区在线免费| 欧美高清电影在线看| 久久久女人电视剧免费播放下载| 国产一级片久久| 亚洲精品乱码久久久久久蜜桃91| 亚洲欧洲日韩精品在线| 亚洲第一区第一页| 日韩欧美在线视频免费观看| 国产精品欧美激情在线观看| 伊人久久成人| av在线二区| 午夜国产福利| 天天综合天天做天天综合| 免费黄网站在线观看| 国产精品羞羞答答| 热这里只有精品| 99精品视频网| 国产欧美一区二区三区四区| 国产极品嫩模在线视频一区| 国产高清无密码一区二区三区| 成人黄色片网站| 91麻豆精品国产91久久久更新时间| 日韩欧美在线第一页| 国产精品99精品久久免费| 一本到不卡免费一区二区| 性色av浪潮av| 99自拍偷拍视频| 中文字幕一区图| 亚洲sss视频| 欧美成人在线免费观看| 传媒视频在线| 亚洲电影一级黄| 波多野结衣激情| 高清一区二区视频| 国产日韩一区在线| 亚洲91视频| 91在线视频播放| 日本一二区免费| 免费成人在线看| 中文字幕精品国产| 91在线网站视频| 国产欧美日韩精品一区二区免费| 欧美疯狂性受xxxxx喷水图片| 日本一级二级视频| 美女又黄又免费| 亚洲黄色a级片| 国产精品女主播一区二区三区| 色香蕉成人二区免费| 久久久久久久麻豆| 日本精品一区二区三区四区的功能| 亚洲欧洲成人在线| 国产精品美女免费视频| 91精品国产综合久久久蜜臀粉嫩| 精品一区二区三区在线观看l| 久久久成人免费视频| 综合激情婷婷| 亚洲国产精选| 在线h片观看| 999精品嫩草久久久久久99| 亚洲嫩模一区| 国产精品亚洲欧美日韩一区在线| 国产精品激情自拍| 亚洲色图校园春色| 95精品视频在线| 久久精品国产99久久99久久久| 亚洲国产一区二区久久| 日本一区不卡| 日韩欧美高清dvd碟片| 黄色片视频免费| 视频一区在线视频| 国产资源第一页| 伊大人久久香线焦宗合一75大| 少妇高潮av久久久久久| 国产ts在线播放| av在线天堂网| www.一区二区.com| 麻豆av在线播放| 三级理论午夜在线观看| 色一情一区二区| 欧美高清视频在线高清观看mv色露露十八| 欧美最猛性xxxxx免费| 综合国产在线观看| 一区二区三区动漫| 唐朝av高清盛宴| 三级网站免费看| 黄色大全在线观看| 欧美激情综合亚洲一二区|