Loading

491. 递增子序列

491. 递增子序列

难度中等566收藏分享切换为英文接收动态反馈

给你一个整数数组 nums ,找出并返回所有该数组中不同的递增子序列,递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。

数组中可能含有重复元素,如出现两个整数相等,也可以视作递增序列的一种特殊情况。

示例 1:

输入:nums = [4,6,7,7]
输出:[[4,6],[4,6,7],[4,6,7,7],[4,7],[4,7,7],[6,7],[6,7,7],[7,7]]

示例 2:

输入:nums = [4,4,3,2,1]
输出:[[4,4]]

提示:

  • 1 <= nums.length <= 15
  • -100 <= nums[i] <= 100

通过次数113,142

提交次数214,998

func findSubsequences(nums []int) [][]int {
    path,res=make([]int,0),make([][]int,0)
    dfs(nums,0)
    return res

}

var (
    path []int
    res [][]int
    
)


func dfs(nums []int,startindex int){
   if len(path)>1{
        tmp:=make([]int,len(path))
        copy(tmp, path)
        res = append(res, tmp)  
     }
        

    history := [201]int{}
    // used:=make(map[int]bool,len(nums))
    for i:=startindex;i<len(nums);i++{
        if len(path)>0  && nums[i]<path[len(path)-1]{//去重
            continue
        }
        if  history[nums[i]+100]==1{//去重
            continue
        }
        history[nums[i]+100]=1 //标记本层的重复元素
        path=append(path,nums[i])
        dfs(nums,i+1) 
        path=path[:len(path)-1]
        
    }
}




posted @ 2023-01-12 10:21  suehoo  阅读(34)  评论(0)    收藏  举报