题目链接: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;
}