LeetCode题解 Permutations II 和 Permutations I ——回溯算法
这个算法感觉还是很陌生的。算法导论里没有讲这个算法,而数据结构与算法分析只用了一节来阐述。我居然跳过去了。。尴尬。
笨方法解决的:
第一题:
给定一个元素不重复的数组,枚举出他们的全排列。
方法1:递归。
a[0] a[1] a[2]...a[n-1]这些元素的全排列,可以在 a[1]...a[n-1]的全排列的基础上,插入一个a[0]就可以获得了。
因为所有元素不重复,那么a[0]的插入位置实际上有n种。
方法2:回溯。实际上是深度优先搜索。
先选取一个点放入数组,再从余下的里面选取一个点,再从余下的选。。。一层层的来。
这里还有一个递归、然后回溯一步。
现在就是死记硬背的算法。实在没有深入的理解!
先记下算法:
class Solution {
public:
vector<vector<int>> permute(vector<int>& nums) {
vector<int> visited(nums.size(),);
vector<int> last;
for(int i = ; i < nums.size(); i ++)
{
visited[i] = ;
last.push_back(nums[i]);
back_track(nums,,visited,last);
last.pop_back();
visited[i] = ;
}
return ans;
}
private:
void back_track( vector<int> &a, int depth,vector<int> &visited, vector<int>&last)
{
if(depth == a.size())
{
ans.push_back(last);
return;
}
for(int i = ; i < a.size(); i++)
{
if(!visited[i])
{
visited[i] = ;
last.push_back(a[i]);
back_track(a,depth + , visited, last);
last.pop_back();
visited[i] = ;
}
}
}
vector<vector<int>> ans;
};
第二题:是有可能有重复的元素,这时候要求给出不重复的全排列。
思考,可能的重复是什么样的呢?
比如 1 1 1 2
按照之前的思路,选a[0]做第一个,或者a[1] a[2] a[3]
这时候,前三个当第一个,其实是一种情况。肯定会重复的。
怎样避免呢?就是保证重复元素在全排列中的顺序,和他们在数组中的顺序是一样的。
怎么实现?也就是 在这个例子中,前三个1的先后顺序必须保持一致。
保证重复的元素只有一种访问顺序,也就是靠前的先访问,靠后的后访问。
对于重复的元素:只有在前面的元素访问过以后,才可以添加后面的元素。
class Solution {
public:
vector<vector<int>> permuteUnique(vector<int>& nums) {
vector<bool>visited(nums.size(),false);
vector<int>& a = nums;
vector<int>last;
sort(a.begin(),a.end());
for(int i = ; i< nums.size(); i++)
{
if(i > && a[i] == a[i-] && visited[i-] == false)
continue;
visited[i] = true;
last.push_back(a[i]);
back_track(a,,visited,last);
last.pop_back();
visited[i] = false;
}
return ans;
}
void back_track(vector<int>& a, int depth, vector<bool> &visited, vector<int>&last)
{
if(depth == a.size())
{
ans.push_back(last);
return;
}
for(int i = ; i < a.size(); i ++)
{
if(!visited[i]) //i 是未添加的
{
if(i > && a[i] == a[i-] && visited[i-] == false)
continue;
visited[i] = true;
last.push_back(a[i]);
back_track(a, depth + ,visited, last );
last.pop_back();
visited[i] = false;
}
}
}
private:
vector<vector<int>> ans;
};
LeetCode题解 Permutations II 和 Permutations I ——回溯算法的更多相关文章
- LeetCode 47. 全排列 II(Permutations II)
题目描述 给定一个可包含重复数字的序列,返回所有不重复的全排列. 示例: 输入: [1,1,2] 输出: [ [1,1,2], [1,2,1], [2,1,1] ] 解题思路 类似于LeetCode4 ...
- Leetcode之回溯法专题-47. 全排列 II(Permutations II)
Leetcode之回溯法专题-47. 全排列 II(Permutations II) 给定一个可包含重复数字的序列,返回所有不重复的全排列. 示例: 输入: [1,1,2] 输出: [ [1,1,2] ...
- leetcode Permutations II 无重全排列
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4051169.html 题目链接:leetcode Permutations II 无重全排 ...
- [Leetcode][Python]47: Permutations II
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 47: Permutations IIhttps://oj.leetcode. ...
- Permutations II - LeetCode
目录 题目链接 注意点 解法 小结 题目链接 Permutations II - LeetCode 注意点 不确定有几种排列 解法 解法一:因为有重复的数字所以排列的个数不确定几个,一直生成新的排列直 ...
- LeetCode: Permutations II 解题报告
Permutations II Given a collection of numbers that might contain duplicates, return all possible uni ...
- LeetCode解题报告—— Permutations & Permutations II & Rotate Image
1. Permutations Given a collection of distinct numbers, return all possible permutations. For exampl ...
- 回溯---Permutations II
47.Permutations II (Medium)](https://leetcode.com/problems/permutations-ii/description/) [1,1,2] hav ...
- 【leetcode】Permutations II
Permutations II Given a collection of numbers that might contain duplicates, return all possible uni ...
随机推荐
- Web jsp开发学习——前端后台传参方法
一.前端传后台: 1.1表单数据的传递 前端的表单里定义名字name 后台通过名字获取输入的值 1.2页面点击了哪个按钮传递 登录注销的另一种方式 点击登录的地方设置参数 ...
- Java-Runoob-高级教程-实例-数组:10. Java 实例 – 查找数组中的重复元素-un
ylbtech-Java-Runoob-高级教程-实例-数组:10. Java 实例 – 查找数组中的重复元素 1.返回顶部 1. Java 实例 - 查找数组中的重复元素 Java 实例 以下实例 ...
- ipv6下jdbc的连接数据库方式
ipv6下jdbc的连接数据库方式 MySQL: ipv4 Driver URL: jdbc:mysql://127.0.0.1:3306/database ipv6 Driv ...
- intent--Activity之间数据传递之Intent数据传递
intent传值: 4,intent传集合 3,intent传对象, 2,传递后有返回值的情况:当需要从目标Activity回传数据到原Activity时,可以使用上述方法定义一个新的Intent来传 ...
- MCC MNC in china
A mobile country code (MCC) is used in combination with a mobile network code (MNC) (a combination k ...
- eMTC/NB/LTE拨号
挂起-恢复流程挂起恢复流程是eMTC/NB-IoT等蜂窝物联网技术才引进的,LTE并不具备这样的流程.这种机制的引入主要针对物联网海量连接,不活跃小数据包的特点,适时的挂起流程可以减少网络的资源开销, ...
- DevExpress的提示框
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- System.Drawing.Graphics.FromImage(Image image)引发内存不足
原因:图片位深度导致的,c# gui 应该无法将32位jpg格式的图片load到内存中 通过对比可成功处理的图片 和 不能处理的图片,发现 CMYK(印刷格式)的图片是无法处理的,具体需要深入 .ne ...
- 深入理解Apache Flink
Apache Flink(下简称Flink)项目是大数据处理领域最近冉冉升起的一颗新星,其不同于其他大数据项目的诸多特性吸引了越来越多人的关注.本文将深入分析Flink的一些关键技术与特性,希望能够帮 ...
- vue 整合element-ui
本文主要介绍如何在vue框架中结合elementUI. 本文主要参考: http://element-cn.eleme.io/#/zh-CN/component/quickstart 1.阅读本文 ...