分享一个 循环版 全排列算法

xk82180316 2010-08-11 12:37:13
这个是我原创的,所以有些错误也不一定

如果你喜欢编程可以一起交流、

#include <iostream>

using namespace std;

int s[] = {'a','b','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;
}


...全文
225 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhengweihit 2010-08-11
  • 打赏
  • 举报
回复
先看看·
ayw215 2010-08-11
  • 打赏
  • 举报
回复
xk82180316 2010-08-11
  • 打赏
  • 举报
回复

#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;
}



5040个,没问题的~
YeBinYe 2010-08-11
  • 打赏
  • 举报
回复
这排序int s[] = {'a','b','e','g','f','c','d'};咋就不能用呢?
黑泡泡选手 2010-08-11
  • 打赏
  • 举报
回复
关注一下
xy_zhang 2010-08-11
  • 打赏
  • 举报
回复
建议你用论坛里面的“插入源代码”再发一遍给大家看。

64,662

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧