LeetCode 376 Wiggle Subsequence DP+思维
作者:互联网
A wiggle sequence is a sequence where the differences between successive numbers strictly alternate between positive and negative. The first difference (if one exists) may be either positive or negative. A sequence with one element and a sequence with two non-equal elements are trivially wiggle sequences.
For example, [1, 7, 4, 9, 2, 5]
is a wiggle sequence because the differences (6, -3, 5, -7, 3)
alternate between positive and negative.
In contrast, [1, 4, 7, 2, 5]
and [1, 7, 4, 5, 5]
are not wiggle sequences. The first is not because its first two differences are positive, and the second is not because its last difference is zero.
A subsequence is obtained by deleting some elements (possibly zero) from the original sequence, leaving the remaining elements in their original order.
Given an integer array nums
, return the length of the longest wiggle subsequence of nums
.
Solution
求最长的 wiggle 序列长度。由于是起伏,所以我们用 \(\text{DpUp,DpDw}\) 表示结尾为上升或者下降的最长 wiggle 子序列长度。考虑如何转移:
如果 \(a[i]>a[i-1]\):
\[\begin{align} DpUp[i] &=DpDw[i-1]+1\\ DpDw[i] &= DpDw[i-1] \end{align} \]如果 \(a[i]<a[i-1]\):
\[\begin{align} DpDw[i] &=DpUp[i-1]+1\\ DpUp[i] &= DpUp[i-1] \end{align} \]点击查看代码
class Solution {
private:
int DpUp[1002];
int DpDw[1002];
public:
int wiggleMaxLength(vector<int>& nums) {
int n = nums.size();
if(n==0)return 0;
if(n==1)return 1;
DpUp[0] = DpDw[0]=1;
for(int i=1;i<n;i++){
if(nums[i]>nums[i-1]){
DpUp[i] = DpDw[i-1]+1; DpDw[i] = DpDw[i-1];
}
else if(nums[i]<nums[i-1]){
DpDw[i] = DpUp[i-1]+1; DpUp[i] = DpUp[i-1];
}
else {
DpDw[i] = DpDw[i-1]; DpUp[i] = DpUp[i-1];
}
}
return max(DpDw[n-1], DpUp[n-1]);
}
};
标签:DpDw,nums,wiggle,int,sequence,Wiggle,Subsequence,DpUp,LeetCode 来源: https://www.cnblogs.com/xinyu04/p/16485810.html