leetcode376. 摆动序列

1.题目描述: 

如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为摆动序列。第一个差(如果存在的话)可能是正数或负数。仅有一个元素或者含两个不等元素的序列也视作摆动序列。例如, [1,7,4,9,2,5]是一个摆动序列,因为差值(6,-3,5,-7,3) 是正负交替出现的。相反,[1,4,7,2,5]和[1,7,4,5,5]不是摆动序列,第一个序列是因为它的前两个差值都是正数,第二个序列是因为它的最后一个差值为零。子序列可以通过从原始序列中删除一些(也可以不删除)元素来获得,剩下的元素保持其原始顺序。给你一个整数数组nums,返回nums中作为摆动序列的最长子序列的长度。

2.贪心算法:

其实不需要删除数组元素来得到序列长度,只要统计序列中波动的波峰和波谷即可,也就是与两侧插值符号改变的地方。序列的两端考虑需要注意。时间复杂度O(n),空间复杂度O(1)。

class Solution {
    public int wiggleMaxLength(int[] nums) {
        if (nums == null || nums.length == 0) return 0;
        int count = 1;
        int preDiff = 0;
        int curDiff = 0;
        for (int i = 1; i < nums.length; i++) {
            curDiff = nums[i] - nums[i - 1];
            if ((preDiff >= 0 && curDiff < 0) || (preDiff <= 0 && curDiff > 0)) {
                count++;
                preDiff = curDiff;//这种写法需要把这段代码放在if内,否则出现相邻元素相等的情况可能会多计算  
            }
        }
        return count;
    }
}

3.动态规划:

class Solution {
    public int wiggleMaxLength(int[] nums) {
        int[][] dp = new int[nums.length][2];
        //设dp状态dp[i][0],表示考虑前i个数,第i个数作为山峰的摆动子序列的最长长度
        //设dp状态dp[i][1],表示考虑前i个数,第i个数作为山谷的摆动子序列的最长长度
        dp[0][0] = 1;
        dp[0][1] = 1;
        for (int i = 1; i < nums.length; i++) {
            dp[i][0] = 1;
            dp[i][1] = 1;
            for (int j = 0; j < i; j++) {
                if (nums[i] > nums[j]) dp[i][0] = Math.max(dp[i][0], dp[j][1] + 1);
                if (nums[i] < nums[j]) dp[i][1] = Math.max(dp[i][1], dp[j][0] + 1);
            }
        }
        return Math.max(dp[nums.length - 1][0], dp[nums.length - 1][1]);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值