carloscn / structstudy

Leetcode daily trainning by using C/C++/RUST programming.
4 stars 1 forks source link

leetcode376:摆动序列(wiggle-subsequence) #144

Open carloscn opened 1 year ago

carloscn commented 1 year ago

问题描述

如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为 摆动序列 。第一个差(如果存在的话)可能是正数或负数。仅有一个元素或者含两个不等元素的序列也视作摆动序列。

例如, [1, 7, 4, 9, 2, 5] 是一个 摆动序列 ,因为差值 (6, -3, 5, -7, 3) 是正负交替出现的。

相反,[1, 4, 7, 2, 5] 和 [1, 7, 4, 5, 5] 不是摆动序列,第一个序列是因为它的前两个差值都是正数,第二个序列是因为它的最后一个差值为零。 子序列 可以通过从原始序列中删除一些(也可以不删除)元素来获得,剩下的元素保持其原始顺序。

给你一个整数数组 nums ,返回 nums 中作为 摆动序列 的 最长子序列的长度 。

 

示例 1:

输入:nums = [1,7,4,9,2,5] 输出:6 解释:整个序列均为摆动序列,各元素之间的差值为 (6, -3, 5, -7, 3) 。 示例 2:

输入:nums = [1,17,5,10,13,15,10,5,16,8] 输出:7 解释:这个序列包含几个长度为 7 摆动序列。 其中一个是 [1, 17, 10, 13, 10, 16, 8] ,各元素之间的差值为 (16, -7, 3, -3, 6, -8) 。 示例 3:

输入:nums = [1,2,3,4,5,6,7,8,9] 输出:2  

提示:

1 <= nums.length <= 1000 0 <= nums[i] <= 1000

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/wiggle-subsequence

carloscn commented 1 year ago

问题分析

static int32_t get_wiggle_count(const int64_t *array, size_t len, size_t *result)
{
    int32_t ret = 0;
    size_t i = 0;
    bool is_positive = 0;
    bool except = 0;

    UTILS_CHECK_LEN(len);
    UTILS_CHECK_PTR(array);
    UTILS_CHECK_PTR(result);

    is_positive = array[1] > array[0];
    for (i = 1; i < len - 1; i ++) {
        except = !is_positive;
        is_positive = array[i + 1] > array[i];
        if (is_positive != except) {
            break;
        }
    }

    *result = i + 1;

finish:
    return ret;
}

static int32_t max_wiggle_sub(const int64_t *array, size_t len, size_t *out)
{
    int32_t ret = 0;
    size_t i = 0;
    int64_t *p = NULL;
    size_t p_len = 0;
    BUFLIST_T *buflist = NULL;
    BUFFER_T *buf = NULL;
    size_t c_wig_count = 0;
    size_t max_wig_count = 0;
    size_t max_index = 0;

    UTILS_CHECK_LEN(len);
    UTILS_CHECK_PTR(array);
    UTILS_CHECK_PTR(out);

    buf = buffer_malloc(BUFFER_DEFUALT_SIZE);
    UTILS_CHECK_PTR(buf);

    ret = buffer_append_array(buf, array, len);
    UTILS_CHECK_RET(ret);

    buflist = buflist_malloc();
    UTILS_CHECK_PTR(buflist);

    ret = buflist_append_all_sub_arrays_by_buffer(buflist, buf);
    UTILS_CHECK_RET(ret);

    // buflist_infolog(buflist);

    for (i = buflist_get_size(buflist) - 1; i > 0; i --) {
        ret = buffer_soft_to_array(buflist_get_buffer_at(buflist, i), &p, &p_len);
        UTILS_CHECK_RET(ret);
        ret = get_wiggle_count(p, p_len, &c_wig_count);
        UTILS_CHECK_RET(ret);
        max_wig_count = (c_wig_count > max_wig_count) ?
                        (max_index = i, c_wig_count):
                        (max_wig_count);
    }

    *out = buffer_get_current_len(buflist_get_buffer_at(buflist, max_index));

finish:
    buffer_free(buf);
    buflist_free(buflist);
    return ret;
}
carloscn commented 1 year ago

code

https://github.com/carloscn/structstudy/commit/2fa24f1994ab3b738b4a69531e25f912a5e29b2e https://review.gerrithub.io/c/carloscn/structstudy/+/550827