博客
关于我
【Leetcode刷题】递增子序列
阅读量:448 次
发布时间:2019-03-06

本文共 1044 字,大约阅读时间需要 3 分钟。

class Solution(object):    def findSubsequences(self, nums):        """        :type nums: List[int]        :rtype: List[List[int]]        """        if not nums:            return []        # 记录结果,需要去重        result = []        # 记录当前路径        path = []        n = len(nums)        # 从nums的哪一位开始深度搜索        def trace(start):            if len(path) >= 2:                # 用切片产生的新对象指向当前path数据,并记录新对象                result.append(path[:])            # 如何去重:令每一层遍历不使用相同的数字            # 记录曾经添加到path中的数字            memo = set()            for i in range(start, n):                # 已经遍历过的数字                if nums[i] in memo:                    continue                if not path:                    path.append(nums[i])                elif nums[i] >= path[-1]:                    path.append(nums[i])                else:                    continue                memo.add(nums[i])                trace(i + 1)                path.pop()        trace(0)        return result

时间复杂度:O(n*2n)。需要遍历每个元素,枚举所有子序列的时间代价是O(2n)

空间复杂度:O(n)。path和memo都需要O(n)的空间

转载地址:http://tylyz.baihongyu.com/

你可能感兴趣的文章
next项目部署到服务器pm2进程守护
查看>>
nexus上传jar
查看>>
Nexus指南中的更新强调集成和透明度的重要性
查看>>
Nexus指南已经发布
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>
ng 指令的自定义、使用
查看>>