Codeforces Round #570 (Div. 3) E - Subsequences 子序列的枚举

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值