Skip to content

1573. Number of Ways to Split a String

Difficulty Topics

Description

Given a binary string s, you can split s into 3 non-empty strings s1, s2, and s3 where s1 + s2 + s3 = s.

Return the number of ways s can be split such that the number of ones is the same in s1, s2, and s3. Since the answer may be too large, return it modulo 109 + 7.

 

Example 1:

Input: s = "10101"
Output: 4
Explanation: There are four ways to split s in 3 parts where each part contain the same number of letters '1'.
"1|010|1"
"1|01|01"
"10|10|1"
"10|1|01"

Example 2:

Input: s = "1001"
Output: 0

Example 3:

Input: s = "0000"
Output: 3
Explanation: There are three ways to split s in 3 parts.
"0|0|00"
"0|00|0"
"00|0|0"

 

Constraints:

  • 3 <= s.length <= 105
  • s[i] is either '0' or '1'.

Solution

number-of-ways-to-split-a-string.py
class Solution:
    def numWays(self, S: str) -> int:
        n = len(S)
        M = 10 ** 9 + 7
        ones = S.count("1")

        if ones % 3: return 0

        if ones == 0: return (((n-1) * (n-2)) // 2) % M

        ones /= 3
        first = second = c = 0

        for s in S:
            if s == "1":
                c += 1

            if c == ones:
                first += 1

            elif c == ones*2:
                second += 1

        return (first * second) % M