题目链接:http://codeforces.com/contest/1183/problem/E
题目大意:

给你一个长度为n的字符串s,让你找到k个子序列。

使得n-(每个子序列的长度最大)的和最小。
输入n, k, s
(1≤n,k≤100)

找不到k个输出0,空串也算一个子序列。

思路:很容易想到就是找长度最大的k个子序列。想到k很小,就可以枚举,但是一直没有找到好的枚举方法,我想可以先枚举长度,再dfs+set去重,但是发现复杂度会很高。例如:aaaa…aaaab。

后来看题解发现:可以用队列+set减少重复的状态,并且通过删除进行枚举。很巧妙的方法。

#include <bits/stdc++.h>
using namespace std;

char a[105];
set<string> st;
queue<string> q;
int n, k;
int dfs()
{
    st.insert(a);
    q.push(a);
    while(!q.empty())
    {
        string t=q.front();
        q.pop();
        int Len=t.length();
        for(int i=0;i<Len;i++)
        {
            string x=t;
            x.erase(i, 1);
            if(st.count(x)==0)
            {
                st.insert(x);
                q.push(x);
            }
            if(st.size()==k)
            {
                break;
            }
        }
        if(st.size()==k)
        {
            break;
        }
    }

    if(st.size()<k)
    {
        printf("-1\n");
        return 0;
    }
    int ans=0, i=0;
    for(set<string>::iterator p=st.begin();p!=st.end();p++)
    {
        ans+=n-(*p).length();
    }
    printf("%d\n",ans);
    return 0;

}

int main()
{
    cin>>n>>k>>a;
    if(k==1)
    {
        printf("0\n");
        return 0;
    }
    dfs();

	return 0;
}