标题:字符全排列[递归]
只看楼主
累成一条狗
Rank: 1
等 级:新手上路
帖 子:5
专家分:3
注 册:2017-5-12
结帖率:100%
已结贴  问题点数:20 回复次数:3 
字符全排列[递归]
Description
将输入的一个字符串中的所有元素进行排序并输出。

Input
不超过5个字符的字符串

Output
所有字符按出现的先后顺序全排列的结果

Sample Input
abc

Sample Output
abc
acb
bac
bca
cab
cba

新手求教,我的代码只能实现全排列,但不能实现 “所有字符按出现的先后顺序全排列”
我的代码:
#include <stdio.h>
#include<string.h>
void paixu(char a[],int k,int n)
{
    int i;
    char t;
    if(k==n-1)
    {
        for(i=0;i<n;i++)
            printf("%c ",a[i]);
        printf("\n");
    }
    else
    {
        for(i=k;i<n;i++)
        {
            t=a[k];a[k]=a[i];a[i]=t;
            paixu(a,k+1,n);
            t=a[k];a[k]=a[i];a[i]=t;
        }
    }
}

int main()
{
    int n;
    char a[10];
    scanf("%s",&a);
    n=strlen(a);
    paixu(a,0,n);
    return 0;
}

运行结果:
abc
a b c
a c b
b a c
b c a
c b a
c a b

搜索更多相关主题的帖子: include 字符串 元素 
2017-05-23 17:56
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:10 
https://bbs.bccn.net/viewthread.php?tid=470540&page=1#pid2596008

这是我很久很久以前写的一个全排列~感觉可以优化~~~可以先凑合看一下吧~~~

PS:全排列算法网上应该是有的~可以上网查查~~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-23 18:59
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:10 
以下是引用累成一条狗在2017-5-23 17:56:09的发言:
新手求教,我的代码只能实现全排列,但不能实现 “所有字符按出现的先后顺序全排列”

先按出现的先后顺序号排列,再对号入座。
2017-05-23 20:17
累成一条狗
Rank: 1
等 级:新手上路
帖 子:5
专家分:3
注 册:2017-5-12
得分:0 
#include<iostream>
using namespace std;


void permute1(string prefix,string str)
{
    if(str.length()==0)
        cout<<prefix<<endl;
    else
    {
        for(int i=0;i<str.length();i++)
            permute1(prefix+str[i],str.substr(0,i)+str.substr(i+1,str.length()));
    }
}
void permute1(string s)
{
    permute1("",s);
}
int main()
{
    int i=0;
    char a[100];
    cin>>a;
    permute1(a);
    return 0;
}

谋定而后动,知止而有得!
2017-05-25 00:21



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-477272-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.167481 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved