Merge pull request #95 from xiaoshuai96/master

solved @xiaoshuai96
This commit is contained in:
程序员吴师兄 2020-05-18 16:28:39 +08:00 committed by GitHub
commit 74af9ba984
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 121 additions and 0 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 MiB

View File

@ -0,0 +1,121 @@
## LeetCode第942号问题增减字符串匹配
> 本文首发于公众号图解面试算法 [图解 LeetCode ](<https://github.com/MisterBooo/LeetCodeAnimation>) 系列文章之一
>
> 同步个人博客www.zhangxiaoshuai.fun
本题在leetcode中题目序号942属于easy级别目前通过率为71.4%
### 题目描述
```
给定只含 "I"增大 "D"减小的字符串 S N = S.length
返回 [0, 1, ..., N] 的任意排列 A 使得对于所有 i = 0, ..., N-1都有
如果 S[i] == "I"那么 A[i] < A[i+1]
如果 S[i] == "D"那么 A[i] > A[i+1]
示例 1
输出"IDID"
输出[0,4,1,3,2]
示例 2
输出"III"
输出[0,1,2,3]
示例 3
输出"DDI"
输出[3,2,0,1]
提示
1 <= S.length <= 10000
S 只包含字符 "I" "D"
```
**题目分析**
```
题目中的意思很明确我们只要满足给出的两个条件即可
1.假如字符串的长度为N那么目标数组的长度就为N+1
2.数组中的数字都是从0~N且没有重复
3.遇见I要增加遇见D要减少
```
### GIF动画演示
![](../Animation/0942-di-String-Match01.gif)
### 代码
```java
//这里搬运下官方的解法
public int[] diStringMatch(String S) {
int N = S.length();
int lo = 0, hi = N;
int[] ans = new int[N + 1];
for (int i = 0; i < N; ++i) {
if (S.charAt(i) == 'I')
ans[i] = lo++;
else
ans[i] = hi--;
}
ans[N] = lo;
return ans;
}
```
**虽然上述代码很简洁好像已经不需要我们去实现什么但是满足条件的序列并不止一种官方的好像只能通过一种下面的代码虽然有些冗余但是得出的序列是满足题意要求的但是并不能AC**
### 思路
```
(1)如果遇见的是I那么对应数组当前位置的数字要小于它右边的第一个数字
(2)如果遇见的是D那么对应数组当前位置的数字要大于它右边的第一个数字
首先对目标数组进行初始化赋值0~N
我们开始遍历字符串如果遇见I就判断对应数组该位置上的数是否满足1号条件
如果满足跳过本次循环如果不满足交换两个数字的位置
对于D也是同样的思路
```
### GIF动画演示
![](../Animation/0942-di-String-Match02.gif)
### 代码
```java
public int[] diStringMatch(String S) {
int[] res = new int[S.length()+1];
String[] s = S.split("");
for (int i = 0; i < res.length; i++) {
res[i] = i;
}
for (int i = 0; i < s.length; i++) {
if (s[i].equals("I")) {
//判断指定位置的数字是否符合条件
if (res[i] < res[i + 1]) {
continue;
} else {
//交换两个数字的位置
res[i] = res[i] ^ res[i+1];
res[i+1] = res[i] ^ res[i+1];
res[i] = res[i] ^ res[i+1];
}
} else {
if (res[i] > res[i + 1]) {
continue;
} else {
res[i] = res[i] ^ res[i+1];
res[i+1] = res[i] ^ res[i+1];
res[i] = res[i] ^ res[i+1];
}
}
}
return res;
}
```
**以上内容如有错误不当之处欢迎批评指正**