zoukankan      html  css  js  c++  java
  • Leetcode 376.摆动序列

    摆动序列

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

    例如, [1,7,4,9,2,5] 是一个摆动序列,因为差值 (6,-3,5,-7,3) 是正负交替出现的。相反, [1,4,7,2,5] 和 [1,7,4,5,5] 不是摆动序列,第一个序列是因为它的前两个差值都是正数,第二个序列是因为它的最后一个差值为零。

    给定一个整数序列,返回作为摆动序列的最长子序列的长度。 通过从原始序列中删除一些(也可以不删除)元素来获得子序列,剩下的元素保持其原始顺序。

    示例 1:

    输入: [1,7,4,9,2,5]

    输出: 6

    解释: 整个序列均为摆动序列。

    示例 2:

    输入: [1,17,5,10,13,15,10,5,16,8]

    输出: 7

    解释: 这个序列包含几个长度为 7 摆动序列,其中一个可为[1,17,10,13,10,16,8]。

    示例 3:

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

    输出: 2

    进阶:
    你能否用 O(n) 时间复杂度完成此题?

     

    思路:

     

    而为了能够在O(n)时间内解决可以考虑使用贪心法. 举个栗子: [1,17,5,10,13,15,10,5,16,8], 可以看到前两个[1, 17]确定了一个递增的序列, 而[17, 5]构成了一个递减序列, 所以到目前位置都正常. 到了[10, 13, 15]这里就有问题了, 他们和之前的5构成了一个递增序列, 而出于贪心的考虑, 必然是选择15是最优解, 因为这样给后面序列最大的选择空间. 对于接下来的[10, 5]都与之前的15构成递减区间, 同样道理我们选择5来构造这个序列. 所以一个基于贪心的算法大概就是这样了. 其时间复杂度为(n), 空间复杂度为O(1).

     

     

     1 class Solution {
     2     public int wiggleMaxLength(int[] nums) {
     3         if(nums.length<2) return nums.length;
     4         int len=nums.length;
     5         int ans=len;
     6         int flag=0;
     7         for(int i=1;i<len;i++){
     8             if(nums[i]-nums[i-1]==0) ans--;
     9             else if(nums[i]-nums[i-1]>0){
    10                 if(flag==1){
    11                     ans--;
    12                 }else{
    13                     flag=1;
    14                 }
    15             }
    16             else if(nums[i]-nums[i-1]<0){
    17                 if(flag==-1){
    18                     ans--;
    19                 }else{
    20                     flag=-1;
    21                 }
    22             }
    23         }
    24         return ans;
    25     }
    26 }
  • 相关阅读:
    数据类面试题
    java二进制文件复制
    String源码
    集合类题目
    OBJ-C
    java文件(文件夹)操作
    java中输入方式Scanner和BufferedReader
    二次分发举例
    Eclipse常用快捷键
    c#获取新浪微博登录cookie
  • 原文地址:https://www.cnblogs.com/kexinxin/p/10235339.html
Copyright © 2011-2022 走看看