• 刷题-力扣-1585. 检查字符串是否可以通过排序子字符串得到另一个字符串


    1585. 检查字符串是否可以通过排序子字符串得到另一个字符串

    题目链接

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/check-if-string-is-transformable-with-substring-sort-operations/
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    题目描述

    给你两个字符串 s 和 t ,请你通过若干次以下操作将字符串 s 转化成字符串 t :
    选择 s 中一个 非空 子字符串并将它包含的字符就地 升序 排序。
    比方说,对下划线所示的子字符串进行操作可以由 "14234" 得到 "12344" 。
    如果可以将字符串 s 变成 t ,返回 true 。否则,返回 false 。
    一个 子字符串 定义为一个字符串中连续的若干字符。

    示例 1:

    输入:s = "84532", t = "34852"
    输出:true
    解释:你可以按以下操作将 s 转变为 t :
    "84532" (从下标 2 到下标 3)-> "84352"
    "84352" (从下标 0 到下标 2) -> "34852"
    

    示例 2:

    输入:s = "34521", t = "23415"
    输出:true
    解释:你可以按以下操作将 s 转变为 t :
    "34521" -> "23451"
    "23451" -> "23415"
    

    示例 3:

    输入:s = "12345", t = "12435"
    输出:false
    

    示例 4:

    输入:s = "1", t = "2"
    输出:false
    

    提示:

    • s.length == t.length
    • 1 <= s.length <= 105
    • s 和 t 都只包含数字字符,即 '0' 到 '9' 。

    题目分析

    1. 根据题目描述将s按照升序改变排序转换为t
    2. 使用vector<queue>记录s中各个字母出现的顺序
    3. 遍历t比较t中字母是否可以移动

    代码

    class Solution {
    public:
        bool isTransformable(string s, string t) {
            vector<queue<int>> pos(10);
            for (int i = 0; i < s.length(); ++i) pos[s[i] - '0'].push(i);
            for (int i = 0; i < t.length(); ++i) {
                int digit = t[i] - '0';
                if (pos[digit].empty()) return false;
                for (int j = 0; j < digit; ++j) 
                    if (!pos[j].empty() && pos[j].front() < pos[digit].front()) return false;
                pos[digit].pop();
            }
            return true;
        }
    };
    
  • 相关阅读:
    快速理解平衡二叉树、B-tree、B+tree、B*tree
    centos 7(6) linux系统安装 mysql5.7.17(glibc版)
    关于使用Hibernate+spring+dubbo的实现微服务对象查询
    Keepalived+Nginx实现高可用(HA)
    Nginx源码安装
    Keepalived安装与配置
    单点fastDfs+centos7搭建
    Dubbo+zookeeper使用方法以及注意事项
    mac 下 iterm2 不能使用 rz sz
    java 无符号整型
  • 原文地址:https://www.cnblogs.com/HanYG/p/14610440.html
Copyright © 2020-2023  润新知