JavaInterview JavaInterview
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)

『Java面试+Java学习』
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)
  • 指南
  • 简历

  • Java

  • 面试

  • 算法

  • algorithm
  • leetcode
JavaInterview.cn
2025-05-10
目录

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

文章发布较早,内容可能过时,阅读注意甄别。

# 题目

给你两个字符串 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' 。

# 思路

其实 只要 t 从后往前的 每个 数字 number, 只要 (number , 9] 的中的每个数在 s 中的 最后位置 比 number 在 s 中的位置小 就行。

# 解法

class Solution {
    public boolean isTransformable(String s, String t) {
        int n = s.length();
        char[] arrS = s.toCharArray();
        char[] arrT = t.toCharArray();
        LinkedList<Integer>[] record = new LinkedList[10];
        for (int i = 0; i < 10; i++) {
            record[i] = new LinkedList<>();
        }
        for (int i = 0; i < n; i++) {
            record[arrS[i] - '0'].add(i);
        }
        for (int i = n - 1; i >= 0; i--) {
            int v = arrT[i] - '0';
            if (record[v].size() == 0) return false;
            int index = record[v].removeLast();
            for (int j = v + 1; j < 10; j++) {
                if (record[j].size() > 0 && record[j].getLast() > index) {
                    return false;
                }
            }
        }
        return true;
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

# 总结

  • 分析出几种情况,然后分别对各个情况实现
微信 支付宝
#Java
最近更新
01
1633. 各赛事的用户注册率 Java
07-13
02
1636. 按照频率将数组升序排序 Java
07-13
03
1640. 能否连接形成数组 Java
07-13
更多文章>
Theme by Vdoing | Copyright © 2019-2025 JavaInterview.cn
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式