• LeetCode 926. Flip String to Monotone Increasing


    原题链接在这里:https://leetcode.com/problems/flip-string-to-monotone-increasing/

    题目:

    A string of '0's and '1's is monotone increasing if it consists of some number of '0's (possibly 0), followed by some number of '1's (also possibly 0.)

    We are given a string S of '0's and '1's, and we may flip any '0' to a '1' or a '1' to a '0'.

    Return the minimum number of flips to make S monotone increasing.

    Example 1:

    Input: "00110"
    Output: 1
    Explanation: We flip the last digit to get 00111.
    

    Example 2:

    Input: "010110"
    Output: 2
    Explanation: We flip to get 011111, or alternatively 000111.
    

    Example 3:

    Input: "00011000"
    Output: 2
    Explanation: We flip to get 00000000. 

    Note:

    1. 1 <= S.length <= 20000
    2. S only consists of '0' and '1' characters.

    题解:

    Say up to i, we have already flip as minimum number of flips needed.

    Then it comes to i + 1. If it is 1, then there is nothing changed.

    If it is 0, there are 2 options, either convert it to 1, then it needs flip + 1.

    Or convert all previous 1 into 0, then it needs oneCount. Take the minimum.

    Time Complexity: O(n). n = S.length().

    Space: O(1).

    AC Java:

     1 class Solution {
     2     public int minFlipsMonoIncr(String S) {
     3         int oneCount = 0;
     4         int flip = 0;
     5         for(int i = 0; i < S.length(); i++){
     6             if(S.charAt(i) == '1'){
     7                 oneCount++;
     8             }else{
     9                 flip = Math.min(flip + 1, oneCount);
    10             }
    11         }
    12         
    13         return flip;
    14     }
    15 }
  • 相关阅读:
    xml基础一
    FileStream
    串口、COM口、RS232、RS485、USB区别
    DotNet知识点五
    DotNet知识点四
    DotNet知识点三
    DotNet知识点二
    day02 关键字、添加注释、标识符、常量、变量、变量的定义、变量定义注意事项、转义字符
    day01
    22_Map集合(重点)
  • 原文地址:https://www.cnblogs.com/Dylan-Java-NYC/p/12442448.html
Copyright © 2020-2023  润新知