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]
}
}
作者:suehoo
出处:https://www.cnblogs.com/suehoo/p/17045723.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具