#Leetcode# 942. DI String Match
Posted 丧心病狂工科女
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了#Leetcode# 942. DI String Match相关的知识,希望对你有一定的参考价值。
https://leetcode.com/problems/di-string-match/
Given a string S
that only contains "I" (increase) or "D" (decrease), let N = S.length
.
Return any permutation A
of [0, 1, ..., N]
such that for all i = 0, ..., N-1
:
- If
S[i] == "I"
, thenA[i] < A[i+1]
- If
S[i] == "D"
, thenA[i] > A[i+1]
Example 1:
Input: "IDID"
Output: [0,4,1,3,2]
Example 2:
Input: "III"
Output: [0,1,2,3]
Example 3:
Input: "DDI"
Output: [3,2,0,1]
Note:
1 <= S.length <= 10000
S
only contains characters"I"
or"D"
.
代码:
class Solution { public: vector<int> diStringMatch(string S) { vector<int> ans; int n = S.length(); int numi, numd; for(int i = 0; i < n; i ++) { if(S[i] == ‘I‘) numi ++; else numd ++; } if(numi == n) { for(int i = 0; i <= n; i ++) ans.push_back(i); } else if(numd == n) { for(int i = n; i >= 0; i --) ans.push_back(i); } else { int st = 0, en = n; for(int i = 0; i < n; i ++) { if(S[i] == ‘I‘) { ans.push_back(st); st ++; } else { ans.push_back(en); en --; } } ans.push_back(st); } return ans; } };
控诉 fh 讲错公式 我的四个小时 赔
以上是关于#Leetcode# 942. DI String Match的主要内容,如果未能解决你的问题,请参考以下文章
[LeetCode] 942. DI String Match 增减DI字符串匹配
LeetCode 942 DI String Match 解题报告
LeetCode 942 增减字符串匹配[贪心 双指针] HERODING的LeetCode之路
LeetCode 942. 增减字符串匹配 / 1728. 猫和老鼠 II(博弈,不会) / 449. 序列化和反序列化二叉搜索树