题目链接:LeetCode 1585. 检查字符串是否可以通过排序子字符串得到另一个字符串
题意:
给你两个字符串 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"
解题思路:
当一个小一点的数想要往后走,但是一个大的数挡在了他后面,那么无论再怎么排序,都不可能成功
例如
s= 29 t= 92 此时9挡在了2 的后面,2无法通过排序到达 最后一位
class Solution {
public:
bool isTransformable(string s, string t) {
vector<int> pos[10];
int n = s.size();
int k = t.size();
if(n != k) { // 如果两个字符串长度不相等,不可能成功
return false;
}
for(int i = 0; i < n; i++) {
pos[s[i] - '0'].push_back(i); // 记录每个数字出现的下标
}
for(int i = n-1; i >= 0; i--) { // 从后往前遍历,使排序的副作用最小化
int c = t[i] - '0'; // 得到当前数字
if(pos[c].size() == 0) { // 如果s字符串中没有这个数字了,那么返回false
return false;
}
int p = pos[c].back(); // 去除当前数字坐标
pos[c].pop_back(); // 扔掉这个数,表示这个数已经计算过
for(int j = c+1; j < 10; j++) {
if(pos[j].size() > 0 && p < pos[j].back()) { // 如果大的数挡在他想要去的后面
return false;
}
}
}
return true;
}
};