题目:
题解:
int** subsetsWithDup(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {
qsort(nums, numsSize, sizeof(int), cmp);
int n = numsSize;
*returnSize = 0;
*returnColumnSizes = malloc(sizeof(int) * (1 << n));
int** ans = malloc(sizeof(int*) * (1 << n));
for (int mask = 0; mask < (1 << n); ++mask) {
int* t = malloc(sizeof(int) * n);
int tSize = 0;
bool flag = true;
for (int i = 0; i < n; ++i) {
if (mask & (1 << i)) {
if (i > 0 && (mask >> (i - 1) & 1) == 0 && nums[i] == nums[i - 1]) {
flag = false;
break;
}
t[tSize++] = nums[i];
}
}
t = realloc(t, sizeof(int) * tSize);
if (flag) {
ans[*returnSize] = t;
(*returnColumnSizes)[(*returnSize)++] = tSize;
}
}
ans = realloc(ans, sizeof(int*) * (*returnSize));
return ans;
}