博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Leetcode]942. DI String Match
阅读量:5095 次
发布时间:2019-06-13

本文共 901 字,大约阅读时间需要 3 分钟。

 

  • Easy
  • Related Topic: Math

Problem

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”, then A[i] < A[i+1]

If S[i] == “D”, then A[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”.


  • O(N)
class Solution:    def diStringMatch(self, S):        """        :type S: str        :rtype: List[int]        """        res = []        l = len(S)        h = 0        t = l        for g in S:            if g == "I":                res.append(h)                h += 1            if g == "D":                res.append(t)                t -= 1        res.append(h)        return res

转载于:https://www.cnblogs.com/siriusli/p/10353414.html

你可能感兴趣的文章
[转]JavaScript快速检测浏览器对CSS3特性的支持
查看>>
对接系统的一些思考
查看>>
exception from hresult:0x8000401A(excel文档导出)
查看>>
Master选举原理
查看>>
CSS 基础知识(认识选择器)
查看>>
[ JAVA编程 ] double类型计算精度丢失问题及解决方法
查看>>
Android Token的使用学习
查看>>
小别离
查看>>
★一张图弄明白从零维到十维
查看>>
Java开发学习心得(一):SSM环境搭建
查看>>
固定渲染管线与可编程渲染管线的区别
查看>>
MVC框架
查看>>
微信小程序-发起 HTTPS 请求
查看>>
<Java><!!!><面试题>
查看>>
oracle 11g 导出数据库时,出现空表无法导出问题解决
查看>>
WPF动画设置1(转)
查看>>
backgound-attachment属性学习
查看>>
个人作业——关于K米的产品案例分析
查看>>
基于node/mongo的App Docker化测试环境搭建
查看>>
java web 中base64传输的坑
查看>>