| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1486 人关注过本帖, 1 人收藏
标题:字符全排列[递归]
只看楼主 加入收藏
累成一条狗
Rank: 1
等 级:新手上路
帖 子:5
专家分:3
注 册:2017-5-12
结帖率:100%
收藏(1)
已结贴  问题点数: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: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册: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
快速回复:字符全排列[递归]
数据加载中...
 
   



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

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