64,662
社区成员
发帖
与我相关
我的任务
分享
#include <iostream>
using namespace std;
int s[] = {'a','b','e','g','f','c','d'};
const int N = sizeof(s)/sizeof(int);
int t[N];
int num;
void p(void);
void f(void);
void swap(int *a, int *b);
int main(int argc, char *argv[])
{
f();
cout << num << endl;
return 0;
}
void f()
{
int a=0;
while(a != -1)
{
if (a == N)
{
p();
a--;
num++;
}
else
{
while (a+t[a] == N)
{
t[a] = 0;
a--;
}
if (a != -1)
{
if (a != a+t[a])
{
swap(&s[a], &s[a+t[a]-1]);
}
swap(&s[a], &s[a+t[a]]);
t[a]++;
a++;
}
}
}
}
void swap(int *a, int *b)
{
int tmp = *a;
*a = *b;
*b = tmp;
}
void p()
{
for (int i=0; i < N; ++i)
{
cout << char(s[i]) << " ";
}
cout << endl;
}