栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

腾讯校招编程题

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

腾讯校招编程题

1.https://www.nowcoder.com/test/question/done?tid=48977681&qid=1795704

aabb那个子串题目

链接:https://www.nowcoder.com/questionTerminal/c59d9690061e448fb8ec7d744c20ebff?f=discussion
来源:牛客网

#include
#include
 
using namespace std;
 
string s;
int k;
 
int main()
{
    cin >> s;
    cin >> k;
    setmin_k;  //用于存储最小的k个子串,存储在set中的元素有序(默认从小到大排序),--min_k.end()是指向容器中字典序最大字符串的指针
    //由于我们维护的set的大小为k,那么说明了在枚举完子串后,第k个最小的string(ans)就是最后那一个
    int lenth = s.size();
    for (int i = 0; i < lenth; i++)
    {
        string tem;
        for (int j = i; j < lenth; j++)
        {
            tem += s[j];
            if (min_k.size() == k)
            {
                if (tem >= *(--min_k.end()))
                {
                    break;
                }
            }
            //发现了一个tem字典序小,需要进来,先插进来,排序好,然后删掉越界的那个
            min_k.insert(tem);
            if (min_k.size() > k)
            {
                min_k.erase(--min_k.end());  //因为可能会存在重复的子串,所以在插入tem后清理超出k的那个元素
                //调用第二种格式的 erase() 方法
    set::iterator iter = myset.erase(myset.begin()); //删除元素 1,myset={3,4,5}
            }
        }
    }
    cout << *(--min_k.end()) << endl;
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/329971.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号