其他分享
首页 > 其他分享> > 2018 蓝桥杯省赛 B 组模拟赛

2018 蓝桥杯省赛 B 组模拟赛

作者:互联网

E

相信大家都知道什么是全排列,但是今天的全排列比你想象中的难一点。我们要找的是全排列中,排列结果互不相同的个数。比如:aab 的全排列就只有三种,那就是aab,baa,aba

代码框中的代码是一种实现,请分析并填写缺失的代码。

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int N=1e3;
char str[N], buf[N];//buffer
int vis[N], total, len;
void arrange(int num) {
    if (num == len){
        printf("%s\n", buf);
        total++;
        return;
    }
    for (int i = 0; i < len; ++i) {
        if (!vis[i]) {
            int j;
            for (j = i + 1; j < len; ++j) {
                if (/*填入代码*/) {
                    break;
                }
            }
            if (j == len) {
                vis[i] = 1;
                buf[num] = str[i];
                arrange(num + 1);
                vis[i] = 0;
            }
        }
    }
}
int main() {
    while (~scanf("%s",str)) {
        len = strlen(str);
        sort(str, str + len);
        total = 0;
        buf[len] = '\0';
        arrange(0);
        printf("Total %d\n", total);
    }
    return 0;
}

题目分析

这个函数可以求出去重后的全排列。如果不填入代码,输入aab,则输出aab aab aba aba baa baa。与题意不符,因此推断,填入代码所在的for循环是用来去重的。

第一个a作为第一个元素形成的序列有aab aba ,如果第二个a开头,那么形成的序列必然和先前的重复。

这种情况可以翻译成:str[j] == s[i]  && vis[j] == 1 (存在 j > i),故填入代码str[i] == str[j] && vis[j]

标签:aab,int,len,蓝桥,vis,2018,str,省赛,include
来源: https://www.cnblogs.com/woxiaosade/p/10806942.html