您的位置:首页 > 其它

LeetCode 2016.3.18 47,31

2016-03-18 11:30 155 查看
47 Permutations II

class Solution {
public:
vector< vector<int> > permuteUnique(vector<int>& nums)
{
sort(nums.begin(),nums.end());
vector< vector<int> > ans;
ans.push_back(nums);
while (next_permutation(nums.begin(),nums.end()))
ans.push_back(nums);
return ans;
}
};


31 Next Permutation

class Solution {
public:
void nextPermutation(vector<int>& nums)
{
int pos=-1;
for(int i=nums.size()-1;i>=0;i--)
{
if (nums[i]>nums[i-1])
{
pos=i-1;
break;
}
}
int i=nums.size();
while (i--)
{
if (pos==-1 || nums[pos]<nums[i])
{
if (pos>=0) swap(nums[pos],nums[i]);
sort(nums.begin()+pos+1,nums.end());
break;
}
}
return ;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: