输入一个字符串, 列举其所有的排列.

xlxlxl1985 2010-12-26 05:45:16
rt.
这道题目该怎么做?
我想出了一个算法.
但是觉得不是最好的, 很多循环...
看看csdn上的各位牛人?..
...全文
148 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
某某9 2010-12-26
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 qq120848369 的回复:]

递归排就可以了,依次安排每一位上字母,可以选择使用swap方法,也可以使用简单的标记办法,只要注意回溯时恢复状态就可以了.

给你写个简易版的,自己琢磨.

C/C++ code
#include <iostream>
using namespace std;

char input[5]="abcd";
int pos[4]={0,1,2,3};

void print(int cu……
[/Quote]
xlxlxl1985 2010-12-26
  • 打赏
  • 举报
回复
那看样子我想对头了, 我用二级指针代替了状态的恢复.
qq120848369 2010-12-26
  • 打赏
  • 举报
回复
递归排就可以了,依次安排每一位上字母,可以选择使用swap方法,也可以使用简单的标记办法,只要注意回溯时恢复状态就可以了.

给你写个简易版的,自己琢磨.

#include <iostream>
using namespace std;

char input[5]="abcd";
int pos[4]={0,1,2,3};

void print(int cur)
{
if(cur==4)
{
for(int i=0;i!=4;++i)
{
cout<<input[pos[i]];
}

cout<<endl;

return;
}

for(int i=cur;i!=4;++i)
{
swap(pos[cur],pos[i]);
print(cur+1);
swap(pos[cur],pos[i]);
}
}

int main()
{
print(0);

return 0;
}
  • 打赏
  • 举报
回复
递归。
shzhfu 2010-12-26
  • 打赏
  • 举报
回复
这应该是《算法分析与设计》中用递归实现排列组合的问题。你去找这方面的参考资料。

64,646

社区成员

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

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