C语言 | Leetcode C语言题解之第491题非递减子序列

题目:

题解:

cpp 复制代码
int** ans;
int ansSize;
int* temp;
int tempSize;

void dfs(int cur, int last, int* nums, int numsSize, int** returnColumnSizes) {
    if (cur == numsSize) {
        if (tempSize >= 2) {
            ans[ansSize] = malloc(sizeof(int) * tempSize);
            memcpy(ans[ansSize], temp, sizeof(int) * tempSize);
            (*returnColumnSizes)[ansSize++] = tempSize;
        }
        return;
    }
    if (nums[cur] >= last) {
        temp[tempSize++] = nums[cur];
        dfs(cur + 1, nums[cur], nums, numsSize, returnColumnSizes);
        tempSize--;
    }
    if (nums[cur] != last) {
        dfs(cur + 1, last, nums, numsSize, returnColumnSizes);
    }
}

int** findSubsequences(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {
    ans = malloc(sizeof(int*) * 32768);
    *returnColumnSizes = malloc(sizeof(int*) * 32768);
    temp = malloc(sizeof(int) * numsSize);
    ansSize = tempSize = 0;
    dfs(0, INT_MIN, nums, numsSize, returnColumnSizes);
    *returnSize = ansSize;
    return ans;
}
相关推荐
夜雨翦春韭1 小时前
【代码随想录Day54】图论Part06
java·开发语言·数据结构·算法·leetcode·图论
玦尘、2 小时前
LeetCode动态规划篇:经典打家劫舍问题
算法·leetcode·动态规划
TimberWill2 小时前
双指针-01-三数之和
数据结构·算法·leetcode
奶茶喵喵叫2 小时前
C语言基本概念----字节与对齐
c语言·算法
南巷逸清风2 小时前
LeetCode 101.对称二叉树
c++·python·算法·leetcode
韭菜盖饭3 小时前
LeetCode每日一题685---冗余连接 II
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农3 小时前
力扣1381:设计一个支持增量操作的栈
数据结构·算法·leetcode
ChoSeitaku4 小时前
链表|反转链表|移除链表元素|链表的中间节点|返回倒数第k个节点|合并两个有序链表(C)
c语言·数据结构·链表
夜雨翦春韭5 小时前
【代码随想录Day58】图论Part09
java·开发语言·数据结构·算法·leetcode·图论
czme5 小时前
C语言数组
c语言