博客
关于我
【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/

你可能感兴趣的文章
nginx学习笔记
查看>>
nginx学习笔记002---Nginx代理配置_案例1_实现了对前端代码的方向代理_并且配置了后端api接口的访问地址
查看>>
nginx学习笔记003---Nginx代理配置_注意,在Windows中路径要用/
查看>>
Nginx学习笔记(一) Nginx架构
查看>>
nginx学习路线
查看>>
Nginx安装
查看>>
Nginx安装SSL模块 nginx: the “ssl” parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx
查看>>
nginx安装stream模块配置tcp/udp端口转发
查看>>
nginx安装Stream模块配置tcp/udp端口转发
查看>>
Nginx安装与常见命令
查看>>
nginx安装与配置
查看>>
【Flink】Flink 2023 Flink 到 Doris 实时写入实践
查看>>
Nginx安装及配置详解
查看>>
nginx安装并配置实现端口转发
查看>>
nginx安装配置
查看>>
Nginx实战之1.1-1.6 Nginx介绍,安装及配置文件详解
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
nginx实现二级域名转发
查看>>
Nginx实现动静分离
查看>>
Nginx实现反向代理负载均衡
查看>>