题解 | #全排列#

全排列

https://www.nowcoder.com/practice/5632c23d0d654aecbc9315d1720421c1

#include <iostream>
#include <cstring>
using namespace std;

char str[7];
char board[7];
bool isused[7];

void myout(int maxlevel,int now){
    if(maxlevel==now){
        for(int i=0;i<maxlevel;i++){
            if(!isused[i]){
                board[now-1]=str[i];
                cout<<board<<endl;
            }
        }
    }
    else{
        for(int i=0;i<maxlevel;i++){
            if(!isused[i]){
                board[now-1]=str[i];
                isused[i]=true;
                myout(maxlevel,now+1);
                isused[i]=false;
            }
        }
    }
}

int main() {
    cin>>str;
    myout(strlen(str),1);
    system("pause");
    return 0;
}

全部评论

相关推荐

头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务