增减字符串匹配--java实现

本文探讨了如何根据含'I'(增大)或'D'(减小)的字符串S生成[0,1,...,N]的排列A,使A的元素按S指示的增减趋势排列。通过实例展示了算法实现,如IDID生成[0,4,1,3,2]等。

1.题目描述:给定只含 “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]

2.分析:’‘I’’,’‘D’’ 可以看做对应的数的增减趋势,’‘I’'表示下一个数会增,则我们把最小的数安排好,则下一个数必增,若还是"I",则把倒数第二小的数安排上,下一个数必增,符合"I"的趋势,以此类推,“D"同理。最后"i”,"j"指向同一个数。

3.代码如下:

class Solution {
    public int[] diStringMatch(String s) {
        int a[] = new int [s.length()+1];
        int i=0;
        int j=s.length();
        for(int k=0;k<s.length();k++){
            if(s.charAt(k) == 'I'){
                a[k] = i;
                i++;
            }
            else{
                a[k] = j;
                j--;
            }
        }
        a[s.length()] = i;
        return a;
    }
}

后记:这道题自己做不出来,是看了别人的代码后自己加以分析的。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值