1. 首页
  2. 课程学习
  3. C++/C
  4. 使用swap函数求解带有重复字符串的全排列

使用swap函数求解带有重复字符串的全排列

上传者: 2019-09-28 15:37:01上传 TXT文件 789B 热度 41次
换种思维,对122,第一个数1与第二个数2交换得到212,然后考虑第一个数1与第三个数2交换,此时由于第三个数等于第二个数,所以第一个数不再与第三个数交换。再考虑212,它的第二个数与第三个数交换可以得到解决221。此时全排列生成完毕。这样我们也得到了在全排列中去掉重复的规则——去重的全排列就是从第一个数字起每个数分别与它后面非重复出现的数字交换。用编程的话描述就是第i个数与第j个数交换时,要求[i,j)中没有与第j个数相等的数。下面给出完整代码:
下载地址
用户评论
码姐姐匿名网友 2019-09-28 15:37:01

没什么特别的。。。。