LeetCode刷题记录(三十五):增减字符串匹配


theme: smartblue

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第7天,点击查看活动详情

增减字符串匹配

image.png

题目解析

题目难度:简单
题目素材解析

根据题目的描述和提供的代码初始模板,只提供了一个素材。

  1. 字符串s。

注意:字符串s的长度在1到10万之间。并且只包含“I”和“D”。

我的解读

这道题比较简单,主要是考察对规律的找寻;只要找寻到规律,就可以得到预期结果。

先看一下概念:要根据字符串s,来排列一个数组;并且这个数组要和字符串中的I、D相呼应。

这里是根据索引位置来进行判断的;在索引 i 下s的字符为I,对应数组中的数字规则需要满足数组 i 位置小于 i+1 位置。

在字符为D时,对应的数组数字规则则相反,需要满足数组 i 位置大于 i+1 位置。

因为数组中的值是[0,n]中的排列;n是字符串s的长度;数组中有着n+1个值,这里包含了0。

所以搞清楚这道题的概念之后,要解决这道题,只需要解决两个问题。

其一,如果出现I,如何保证数组的当前这个数字一定比下一个数字小。

其二,如果出现D,如何保证数组的当前这个数字一定比下一个数字大。

要解决这两个问题不难。

其实就两个中间值就能解决;一个最大值,一个最小值。

在不重复的情况下,当前的最大值一定比下一个数字大;当前的最小值一定比下一个数字小。

得到这个结论,我们就可以开始写代码了。

解题思路

有了上述的结论,开始写代码了。

第一步,先声明出最大值、最小值,分别是字符串s的长度length,和0。

第二步,循环字符串的每一个字符。

第三步,循环体中,判断是I还是D;是I的话,就使用最小值,并且最小值min++;是D的话,就使用最大值max,并且最大值max--。

执行完成后,我们会发现还少了一个元素,那就是剩下的一个值,也就是max和min,这时候max和min是相同的了,将这个值给到数组的最后一位元素即可。

第四步,将数组返回。

代码

```java class Solution { public int[] diStringMatch(String s) { int[] result = new int[s.length() + 1]; int min = 0, max = s.length(); for (int i = 0; i < s.length(); i++) { if(s.charAt(i) == 'D'){ result[i] = max; max--; }else{ result[i] = min; min++; } } result[s.length()] = min; return result; }

} ```

执行结果

比较粗暴的方法,还有待优化。

image.png

Java代码本地执行

Java本地可调试代码,请参考github/Ijiran,可通过索引看到相应代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ijiran

一杯咖啡太贵,一块糖就可以

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值