首页 > 其他 > 详细

全排列

时间:2017-08-07 00:55:24      阅读:284      评论:0      收藏:0      [点我收藏+]

代码:

class Solution {
public:
/**
* @param nums: A list of integers.
* @return: A list of permutations.
*/
vector<vector<int> > permute(vector<int> nums) {
// write your code here
vector<vector<int> > result;
if(nums.size()==0 || nums.size()==1){
result.push_back(nums);
return result;
}
sort(nums.begin(),nums.end());
while(true){
int p,i;
result.push_back(nums);
for(i=nums.size()-1;i>=0;i--){
if(i<=0)
return result;
if(nums[i-1]<nums[i]){
p=i-1;
break;
}
}
for(int j=nums.size()-1;j>p;j--){
if(nums[j]>nums[p]){
swap(nums[p],nums[j]);  
break;
}
}
reverse(nums.begin()+p+1,nums.end());
}
}

};

截图:

技术分享

 

全排列

原文:http://www.cnblogs.com/w1500802028/p/7296475.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!