请问这道“排列”的算法题的代码如何理解呢?希望给出每行代码的注释,非常感谢!
#include<cstdio>
int a[1025] = { 0 };
void NextPermutation(int size)
{
int flag = size - 1;
int tmp;
int i;
while (a[flag - 1] > a[flag] && flag != 0)
{
flag--;
}
if (flag == 0)
{
for (i = 0; i < size; i++)
a[i] = i + 1;
return;
}
for (i = size - 1; i >= flag; i--)
{
if (a[i] > a[flag - 1])
{
temp = a[flag - 1];
a[flag - 1] = a[i];
a[i] = temp;
break;
}
}
while (size - 1 > flag)
{
temp = a[size - 1];
a[size - 1] = a[flag];
a[flag] = temp;
flag++;
size--;
}
}
int main(void)
{
int m, n, k;
int i;
scanf("%d", &m);
while (m)
{
scanf("%d%d", &n, &k);
for(i = 0; i < n; i++)
scanf("%d", &a[i]);
for(i = 0; i < k; i++)
NextPermutation(n);
for (i = 0;i < n; i++)
printf("%d", a[i]);
printf("\n");
m--;
}
return 0;
}