算法刷题-回溯-491.递增子序列,46.全排列,47.全排列 II (python)

491.递增子序列

背景:给一个数组nums,求非递减子序列,即保持数组顺序不变,依次选则元素,找出不递减的元素组合,可以是至少两个元素

思路:还是树形结构选树的思路。这次选择的条件是比选择序列最后一个元素小的话即不满足要求退出重新选下一个数(即continue),为了元素不重复选,需要借助startindex依次筛选所有可能情况;收集结果的条件是:结果至少2个

实践:

复盘:最关键的是数组中可能含有重复元素,如何处理呢,巧妙的方式是所选的元素没有在历史选择元素中,即避开重复元素第一个元素选择两次。


46.全排列

背景:给一个数组,要求返回全排列,注:nums不含重复数字

思路:还是树形结构选树的思路,这和组合的不同在于,组合不关心树的顺序关系,所以选择元素时通过startindex来实现每次选择的元素组合可控。全排列则要关心数据的不同顺序关系,最终只取所有的叶子节点,不同的只是全排列无重复数,每次选择元素只要关心所愿的元素不在已选path里(若在path里继续选下一个元素,即continue),保证不重复即可,选择元素满足全排列长度即可。

实践:

复盘:


47.全排列 II

背景:也是全排列,最大的区别是所给数组里有重复元素

思路:有重复元素则意味着,原来按照上一题全排的结果会有很多重复结果,若只是在收集结果时判断,效率则太低;最好的办法是在选择元素时,引入used标志位,来标志每个元素的使用情况,若是使用过的元素和当前选择元素相同,则跳过(即continue)

实践:

复盘:注意所选元素的使用情况也要所选择情况恢复状态


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值