0
已解决
王博佑
新手守护
新手守护
1013 有重复元素的排列问题经验值:1600
题目描述 Description
设R={ r1, r2 , …, rn}是要进行排列的n个元素。其中元素r1, r2 , …, rn可能相同。试设计一个算法,列出R的所有不同排列。
给定n 以及待排列的n 个元素。计算出这n 个元素的所有不同排列。
输入描述 Input Description
文件的第1 行是元素个数n,1≤n≤500。接下来的1 行是待排列的n个元素。
输出描述 Output Description
计算出的n个元素的所有不同排列输出到文件perm.out中。文件最后1行中的数是排列总数。
样例输入 Sample Input
4 aacc
样例输出 Sample Output
aacc acac acca caac caca ccaa 6
0
已采纳
杜文博
资深守护
资深守护
以下是核心代码:
int main()
{
int n;
sort(a,a+n);
for(int i=0;i<n;i++)
{
b[n-i-1]=a[i];
}
int t=1;
while(strcmp(a,b))
{
t++;
next_permutation(a,a+n);
}
0
0