C++算法:戳印序列原理及实现方法一

简介: C++算法:戳印序列原理及实现方法一

题目

你想要用小写字母组成一个目标字符串 target。

开始的时候,序列由 target.length 个 '?' 记号组成。而你有一个小写字母印章 stamp。

在每个回合,你可以将印章放在序列上,并将序列中的每个字母替换为印章上的相应字母。你最多可以进行 10 * target.length  个回合。

举个例子,如果初始序列为 "?????",而你的印章 stamp 是 "abc",那么在第一回合,你可以得到 "abc??"、"?abc?"、"??abc"。(请注意,印章必须完全包含在序列的边界内才能盖下去。)

如果可以印出序列,那么返回一个数组,该数组由每个回合中被印下的最左边字母的索引组成。如果不能印出序列,就返回一个空数组。

例如,如果序列是 "ababc",印章是 "abc",那么我们就可以返回与操作 "?????" -> "abc??" -> "ababc" 相对应的答案 [0, 2];

另外,如果可以印出序列,那么需要保证可以在 10 * target.length 个回合内完成。任何超过此数字的答案将不被接受。

1 <= stamp.length <= target.length <= 1000

stamp 和 target 只包含小写字母。

分析

自己想出来的笨办法,时间复杂度较低。公认的方法是拓扑排序。

代码

class Solution {
public:
    vector<int> movesToStamp(string stamp, string target) {
        int iWindowCount = target.length() - stamp.length() + 1;
        m_strDebug = target;
        unordered_map<int, unordered_set<int>> vNotSame;
        std::unordered_multiset<int> setNeed;
        for (int i = 0; i < target.size(); i++)
        {
            setNeed.emplace(i);
        }
        vector<vector<int>> vDirect(target.length());
        std::vector<int> vQue;
        for (int i = 0; i < iWindowCount; i++)
        {
            for (int j = 0; j < stamp.size(); j++)
            {
                if (stamp[j] != target[i + j])
                {
                    vNotSame[i].emplace(i + j);
                    vDirect[i + j].emplace_back(i);
                }
            }
            if (!vNotSame.count(i))
            {
                vQue.emplace_back(i);
            }
        }
        int index = 0;
        while (setNeed.size() && (index < vQue.size()))
        {
            const auto cur = vQue[index];
            index++;
            for (int i = 0; i < stamp.length(); i++)
            {
                setNeed.erase(i + cur);
                assert(('?' == m_strDebug[i + cur]) || (m_strDebug[i + cur] == stamp[i]));
                m_strDebug[i + cur] = '?';
                for (const auto& n : vDirect[i + cur])
                {
                    if (!vNotSame.count(n))
                    {
                        continue;
                    }
                    vNotSame[n].erase(i + cur);
                    if (0 == vNotSame[n].size())
                    {
                        vQue.emplace_back(n);
                        vNotSame.erase(n);
                    }
                }
            }
            //    CConsole::Out(m_strDebug);
        }
        vector<int> vRet(vQue.begin(), vQue.begin() + index);
        return setNeed.size() ? vector<int>{} : vector<int>(vRet.rbegin(), vRet.rend());
    }
    string m_strDebug;
};

其它

视频课程

如果你觉得复杂,想从简单的算法开始,可以学习我的视频课程。

https://edu.csdn.net/course/detail/38771

我的其它课程

https://edu.csdn.net/lecturer/6176

测试环境

win7 VS2019 C++17

相关下载

doc版文档,排版好

https://download.csdn.net/download/he_zhidan/88348653


相关文章
|
25天前
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
77 4
|
2月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
54 3
|
1月前
|
算法 容器
令牌桶算法原理及实现,图文详解
本文介绍令牌桶算法,一种常用的限流策略,通过恒定速率放入令牌,控制高并发场景下的流量,确保系统稳定运行。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
令牌桶算法原理及实现,图文详解
|
18天前
|
存储 人工智能 缓存
【AI系统】布局转换原理与算法
数据布局转换技术通过优化内存中数据的排布,提升程序执行效率,特别是对于缓存性能的影响显著。本文介绍了数据在内存中的排布方式,包括内存对齐、大小端存储等概念,并详细探讨了张量数据在内存中的排布,如行优先与列优先排布,以及在深度学习中常见的NCHW与NHWC两种数据布局方式。这些布局方式的选择直接影响到程序的性能,尤其是在GPU和CPU上的表现。此外,还讨论了连续与非连续张量的概念及其对性能的影响。
42 3
|
23天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法与应用
探索人工智能中的强化学习:原理、算法与应用
|
23天前
|
存储 算法 安全
SnowflakeIdGenerator-雪花算法id生成方法
SnowflakeIdGenerator-雪花算法id生成方法
20 1
|
1月前
|
负载均衡 算法 应用服务中间件
5大负载均衡算法及原理,图解易懂!
本文详细介绍负载均衡的5大核心算法:轮询、加权轮询、随机、最少连接和源地址散列,帮助你深入理解分布式架构中的关键技术。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
5大负载均衡算法及原理,图解易懂!
|
1月前
|
缓存 算法 网络协议
OSPF的路由计算算法:原理与应用
OSPF的路由计算算法:原理与应用
45 4
|
1月前
|
存储 算法 网络协议
OSPF的SPF算法介绍:原理、实现与应用
OSPF的SPF算法介绍:原理、实现与应用
78 3
|
23天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法及应用
探索人工智能中的强化学习:原理、算法及应用
下一篇
DataWorks