博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode]46. Permutations
阅读量:6363 次
发布时间:2019-06-23

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

 

总流程是递归:参考

方法一:用visited记录是否遍历

class Solution {public:    vector
> permute(vector
&num) { vector
> res; vector
out; vector
visited(num.size(), 0); permuteDFS(num, 0, visited, out, res); return res; } void permuteDFS(vector
&num, int level, vector
&visited, vector
&out, vector
> &res) { if (level == num.size()) res.push_back(out); else { for (int i = 0; i < num.size(); ++i) { if (visited[i] == 0) { visited[i] = 1; out.push_back(num[i]); permuteDFS(num, level + 1, visited, out, res); out.pop_back(); visited[i] = 0; } } } }};

 

方法二:交换数字

class Solution {public:    vector
> permute(vector
&num) { vector
> res; permuteDFS(num, 0, res); return res; } void permuteDFS(vector
&num, int start, vector
> &res) { if (start >= num.size()) res.push_back(num); for (int i = start; i < num.size(); ++i) { swap(num[start], num[i]); permuteDFS(num, start + 1, res); swap(num[start], num[i]); } }};

 

转载于:https://www.cnblogs.com/bright-mark/p/9458771.html

你可能感兴趣的文章
【微信公众号开发】获取并保存access_token、jsapi_ticket票据(可用于微信分享、语音识别等等)...
查看>>
seajs在jquery多个版本下引用jquery的插件的方案
查看>>
Session 撰改演示
查看>>
事务隔离级别(图文详解)
查看>>
又一个 iOS 侧边栏组件: SideMenu
查看>>
espresso 2.0.4 Apple Xcode 4.4.1 coteditor 价格
查看>>
Goldengate 维护
查看>>
ASP.NET没有魔法——ASP.NET MVC使用Oauth2.0实现身份验证
查看>>
所有转义字符
查看>>
C# 属性事件一些设置说明
查看>>
去除UITableViewheader footer黏性
查看>>
windows2003 iis6.0不能显示asp.net选项
查看>>
xen MacOS
查看>>
如何学好C和C++
查看>>
Gitlab通过custom_hooks自动更新服务器代码
查看>>
我的友情链接
查看>>
python 如何判断调用系统命令是否执行成功
查看>>
Lesson10 vSphere 管理特性
查看>>
memcache 扩展和 memcached扩展安装
查看>>
好程序员的查克拉---自信
查看>>