力扣------子集 II

在这里插入图片描述

/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */
int** subsetsWithDup(int* nums, int numsSize, int* returnSize, int** returnColumnSizes){
    *returnSize=0;
    int flag=0;
    int d;
    int sum[21]={0};
    int sum1[21]={0};
    *returnColumnSizes=(int*)calloc(10000,sizeof(int));
    int** ans=(int**)calloc(10000,sizeof(int*));
    (*returnColumnSizes)[*returnSize]=0;
    *returnSize=*returnSize+1;
    for(int a=0;a<numsSize;a++){
        ans[*returnSize]=(int*)calloc(10,sizeof(int));
        ans[*returnSize][0]=nums[a];
        (*returnColumnSizes)[*returnSize]=1;
        for(int e=1;e<=*returnSize-1;e++){
            if((*returnColumnSizes)[e]==1){
                if(ans[e][0]==nums[a]){
                    flag=1;
                }
            }
        }
        if(flag==0){
            *returnSize=*returnSize+1;
            d=*returnSize;
        }
        else{
            d=*returnSize+1;
        }
        flag=0;
        for(int b=1;b<d-1;b++){
            ans[*returnSize]=(int*)calloc(10,sizeof(int));
            for(int c=0;c<(*returnColumnSizes)[b];c++){
                ans[*returnSize][c]=ans[b][c];
            }
            ans[*returnSize][(*returnColumnSizes)[b]]=nums[a];
            (*returnColumnSizes)[*returnSize]=(*returnColumnSizes)[b]+1;
            int flag1=0;
            for(int e=1;e<=*returnSize-1;e++){
                flag=0;
                for(int g=0;g<21;g++){
                    sum[g]=0;
                    sum1[g]=0;
                }
                if((*returnColumnSizes)[e]==(*returnColumnSizes)[*returnSize]){
                    for(int f=0;f<(*returnColumnSizes)[e];f++){
                        if(ans[e][f]>=0){
                            sum[ans[e][f]]=sum[ans[e][f]]+1;
                        }
                        else{
                            sum[ans[e][f]*(-1)+10]=sum[ans[e][f]*(-1)+10]+1;
                        }
                        if(ans[*returnSize][f]>=0){
                            sum1[ans[*returnSize][f]]=sum1[ans[*returnSize][f]]+1;
                        }
                        else{
                            sum1[ans[*returnSize][f]*(-1)+10]=sum1[ans[*returnSize][f]*(-1)+10]+1;
                        }
                    }
                    for(int h=0;h<21;h++){
                        if(sum[h]==sum1[h]){
                            flag++;
                        }
                    }
                    if(flag==21){
                        flag1=1;
                        break;
                    }
                }
            }
            if(flag1==0){
                *returnSize=*returnSize+1;
            }
            flag1=0;
        }
    }
    return ans;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值