最长字符串 / STL+BFS

题目

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main()
{
    map<vector<int>, vector<string>> a;
    set<vector<int>> c;
    vector<int> initial(26, 0);
    c.insert(initial);
    ifstream infile("words.txt");
    string s;

    while (getline(infile, s))
    {
        vector<int> b(26, 0);
        for (size_t j = 0; j < s.size() - 1; j++)
            b[s[j] - 'a']++;
        a[b].push_back(s);
    }

    string e = "~";
    while (!c.empty())
    {
        set<vector<int>> temp_d;
        for (const auto &i : c)
        {
            if (a.find(i) == a.end())
                continue;
            for (const string &j : a[i])
            {
                if (j.size() > e.size())
                    e = j;
                else if (j < e)
                    e = j;
                vector<int> k = i;
                k[j.back() - 'a']++;
                if (a.find(k) != a.end())
                    temp_d.insert(k);
            }
        }
        c = temp_d;
    }
    cout << e;
    return 0;
}
相关推荐
_OP_CHEN4 小时前
【算法基础篇】(六十一)SG 函数通关指南:博弈论通用解法,从原理到实战秒杀各类 ICG 游戏
算法·蓝桥杯·c/c++·博弈论·acm/icpc·sg函数·有向图游戏
阿i索5 小时前
【蓝桥杯备赛Day1】——语法基础+string基础操作
蓝桥杯·打卡
Epiphany.5565 小时前
蓝桥杯2024年第十五届决赛真题-套手镯
c++·算法·蓝桥杯
_OP_CHEN1 天前
【算法基础篇】(六十)Nim 博弈超全解析:从基础原理到经典变种,玩转多堆取石子问题
算法·蓝桥杯·c/c++·博弈论·算法竞赛·acm、icpc·nim博弈
BLOLCO2 天前
揭秘变色马克杯性价比之王:这家生产商为何让同行颤抖?
蓝桥杯
旭意2 天前
算法模拟--字符串的展开
c++·算法·蓝桥杯
闻缺陷则喜何志丹3 天前
【有序集合 小根堆】P8803 [蓝桥杯 2022 国 B] 费用报销|普及+
c++·算法·蓝桥杯·有序集合·洛谷·小根堆
南极星10053 天前
蓝桥杯JAVA--真题之路(一)
java·算法·蓝桥杯
代码无bug抓狂人3 天前
C语言之外卖店优先级(蓝桥杯省A)
c语言·开发语言·蓝桥杯
仰泳的熊猫3 天前
题目1454:蓝桥杯历届试题-蚂蚁感冒
数据结构·c++·算法·蓝桥杯