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

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

【C語言】LeetCode 18 4Sum

2019-11-14 11:10:07
字體:
供稿:網(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,則跳過            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問題
上一篇:13.1.1

下一篇:基礎(chǔ)算法與常用格式

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
99在线视频影院| 国产精品麻豆一区二区| 天天干天天操天天干天天操| 怡红院在线播放| 欧美极品第一页| 日韩欧美电影一区| 高清亚洲成在人网站天堂| 岛国大片在线播放| 91美女片黄在线观看游戏| 九色porny自拍视频在线观看| 在线精品视频在线观看高清| 99久久婷婷国产综合精品青牛牛| 可以免费看的黄色网址| 色撸撸在线观看| 日本天堂网在线| 狠狠色噜噜狠狠狠| 涩涩屋黄网站| 91sp网站在线观看入口| 这里是久久伊人| 丝袜美腿一区| 嫩草影院中文字幕| 国产高清自产拍av在线| 日韩av最新在线观看| 一区二区欧美视频| 影音先锋成人资源网站| 精品三级久久| 国产精品午夜电影| 亚洲一区二区免费在线观看| 99久热re在线精品996热视频| av在线不卡免费| 亚洲精品资源| 五月天视频在线观看| 中文字幕4区| 美女福利网站视频在线观看| 樱花视频在线免费观看| 宅男噜噜噜66国产日韩在线观看| 国产高潮又爽又无遮挡又免费| 色偷偷www8888| 黑人极品videos精品欧美裸| 四虎成人在线| 亚洲欧美中文另类| 日韩精品欧美大片| 欧美一级片在线视频| 久草手机视频在线观看| 中文字幕亚洲综合久久筱田步美| 久久综合狠狠综合久久综合88| 中国一区二区视频| 亚洲第一二三区| 中文字幕av一区二区三区佐山爱| 天天爱天天做色综合| 欧美成人精品欧美一级乱| 一区三区自拍| 久久福利网址导航| 国产精品99久久久久久久女警| 久久夜色电影| 天堂av在线免费观看| 日韩一区二区视频在线观看| 成人免费一区二区三区牛牛| 美女国产精品久久久| 亚洲女同性videos| 午夜国产一级| av色图一区| 国产精品高潮呻吟视频| 网曝91综合精品门事件在线| 成人综合在线视频| 日本少妇一区二区| 亚洲精品一区二区三区蜜桃久| 欧洲精品久久久久毛片完整版| 久久人人爽国产| jizzjizzjizz国产| 午夜av中文字幕| 久久99性xxx老妇胖精品| 精品无吗乱吗av国产爱色| 亚洲国产乱码最新视频| 午夜精品久久久久99热蜜桃导演| 在线综合+亚洲+欧美中文字幕| 欧美国产视频在线| av手机免费看| 久久亚洲春色中文字幕| 亚洲天堂网站在线| 成年人三级视频| 91精品国产自产在线观看永久∴| 亚洲大片精品永久免费| 中文字幕+乱码+中文乱码91| 91久久影院| 麻豆国产91在线播放| 国产美女视频一区二区二三区| 国产乱码精品一区二区三| 22288色视频在线观看| 亚洲ⅴ国产v天堂a无码二区| 欧美性猛交xxxx乱大交丰满| 精品国产免费人成电影在线观看四季| 91精品国产免费| 欧美亚洲高清| 日韩欧美伦理电影院| 亚洲激情在线看| 97人人模人人爽人人喊中文字| 午夜精品久久久久久久99热影院| 亚洲bt欧美bt精品777| 日日摸夜夜添夜夜添毛片av| a级毛片免费| 中文字幕天天干| 免费观看羞羞视频网站| 国产精品盗摄久久久| 午夜先锋成人动漫在线| 一道本在线观看| a视频在线观看免费| 日韩亚洲欧美一区二区三区| 国产亚洲欧美在线视频| 国产网站免费看| 牛牛精品在线视频| 日韩毛片在线视频| 色噜噜夜夜夜综合网| 精品一区精品二区| 国产欧美日韩亚洲| 免费黄色地址| 人人妻人人做人人爽| 高潮毛片又色又爽免费| 久久xxxx精品视频| 99re视频| 亚洲日本va中文字幕久久| 久久久精彩视频| 日日夜夜网站| 欧美韩国日本不卡| 日韩电影网在线| 成人在线免费看| www.欧美精品一二三区| 亚洲一区二区在线观| 校园春色欧美| 天天爽夜夜爽夜夜爽| 欧美中文在线视频| 美女做爰内谢全过程视频| 国产 国语对白 露脸| 欧美偷拍视频| 青青草97国产精品麻豆| 九色综合狠狠综合久久| www.久久av.com| 素人啪啪色综合| 日本黄色免费片| 成人欧美一区二区三区的电影| 蜜桃av噜噜一区| 成人影院中文字幕| 久久亚洲二区三区| 含羞草激情视频| 在线精品福利| 激情综合五月| 国 产 黄 色 大 片| 国产图片综合| 婷婷丁香久久五月婷婷| 成人亚洲网站| 久久电影中文字幕| 黄色片免费在线观看| 日韩中文字幕av电影| 杨幂一区二区国产精品| 国产精品一区二区三区毛片淫片| 少妇大叫太粗太大爽一区二区| 在线国产日韩| 亚洲欧美在线x视频| 亚洲综合资源| 91在线免费视频| 欧美在线免费视屏| 一区二区三区在线看| 国产又爽又黄无码无遮挡在线观看| 国产在线欧美日韩| 久久国产精品色婷婷| 蜜桃传媒在线| 99久久夜色精品国产亚洲| 中文字幕亚洲自拍| 久久天天躁狠狠躁夜夜爽蜜月| а√最新版天堂中文在线| 午夜不卡av免费| 一级片视频免费| 国产乱码精品一区二区三区卡| 91麻豆免费在线观看| 久久国产视频网| 亚洲三级观看| 欧美性大战久久| 国产精品久久久久影院色老大| 青青影院在线观看| 另类的小说在线视频另类成人小视频在线| h网址在线观看| 97操碰视频| 欧美在线视频不卡| av天在线观看| 亚洲精品专区| 午夜日韩av| 国产精品中文字幕制服诱惑| 性欧美videos白嫩| 99久久这里有精品| av网站一区二区三区| 亚洲高清网站| 国产精品视频在线观看免费| av香蕉成人| 琪琪第一精品导航| 美女洗澡无遮挡| 国产精品激情av电影在线观看| 秋霞电影一区二区| 99久久久久成人国产免费| 日日操免费视频| 猫咪av网站| 久久免费大视频| 黄色漫画在线免费观看| 免费在线观看黄视频| 国产午夜精品一区二区三区嫩草| 日韩在线看片| 国产人成免费视频| 小小女视频网站色琼网站| 国产精品99免视看9| 97在线影院| 91精品国产高久久久久久五月天| 五月天综合视频| 一区二区三区电影网| 国产又粗又大又爽视频| 亚洲黄色在线视频| 欧美一区二区三区久久综合| 老司机性视频| 国产精品美女高潮无套| 4438欧美| 好男人看片在线观看免费观看国语| 成人爽a毛片免费啪啪红桃视频| 日韩av一级大片| 欧美精品1区2区| 免费毛片大全| 中文在线а√在线| 日本在线视频中文字幕| 久久96国产精品久久99软件| 69堂免费视频| 青草视频在线观看视频| 久久99国产精品久久99大师| 欧美综合国产精品久久丁香| 午夜免费久久久久| 久久99国产精品麻豆| 岛国一区二区三区| 91丨porny丨九色| www.激情网.com| 免费在线观看日韩欧美| 人人爽久久涩噜噜噜网站| 国产一级做a爰片在线看免费| 免费在线看黄网站| 国产精品第100页| 亚洲精品成人在线视频| 欧美日韩一区二区在线观看| 国产乱淫av麻豆国产免费| 日本aaa在线观看| 国产精品区一区二区三| wwwxxx色| 欧美69精品久久久久久不卡| 亚洲欧洲动漫| 天天干中文字幕| 91中文字幕在线视频| 911精品美国片911久久久| 黄色录像1级片| 粉嫩久久99精品久久久久久夜| 不卡av在线网站| 97超碰在线公开在线看免费| 日韩欧美电影一区| 国产性猛交xx乱| 国产精品私人自拍| 久久这里只有精品9| 青青草在线观看视频| 欧美mv日韩mv国产网站app| 久草在线新资源| 日产电影一区二区三区| 国产一区高清| 国产精品不卡一区二区三区在线观看| 精品久久久久久久久久久久久久久久久久| 日产精品久久久| 精品久久国产97色综合| 制服丝袜第二页| 午夜在线免费观看视频| 亚洲成人黄色| 天海翼在线视频| 国产美女喷水视频| 韩国精品视频| 美日韩一级片在线观看| 欧美精品久久| 国产精品夜夜嗨| 亚洲va国产va欧美va观看| 久久精品官网| 久久国产精品亚洲人一区二区三区| 国产三级av在线| 久久中文字幕视频| 水蜜桃精品av一区二区| 在线激情视频| 樱花影视一区二区| 国产精品免费在线播放| 无遮挡的视频在线观看| 另类成人小视频在线| 欧美久久电影| 成人在线看片网站| 亚洲自拍另类欧美丝袜| 欧美a在线视频| 国产99久久精品一区二区 夜夜躁日日躁| 欧美日韩成人在线观看| 黄页在线免费看| 岛国av一区| 大胆欧美人体视频| 国产精品一区视频网站| 国产精品永久入口久久久| 国产精品国产三级国产在线观看| 在线观看免费黄色小视频| 国外成人在线视频网站| 四虎精品成人a在线观看| 亚洲国产中文字幕| 欧美色图第二页| 久久综合网色—综合色88| 亚洲1234区| 中国一区二区三区| 欧美一区二区三区另类| 欧美日韩一区二区三区在线免费观看| 97精品国产91久久久久久| 中文天堂在线资源| 亚洲欧洲精品在线观看| 日韩欧美精品一区二区三区经典| 99精品免费在线观看| 九九热在线视频免费观看| 三级黄色片播放| 日本vs亚洲vs韩国一区三区| 成人无码av片在线观看| 欧美激情一区二区| 国产人成一区二区三区影院| 午夜不卡av在线| 欧美视频在线观看一区二区| 一区中文字幕在线观看| 日本高清视频在线| 福利一区福利二区| 国产夫妻在线| 麻豆资源在线|