1573. Number of Ways to Split a String
https://leetcode.com/problems/number-of-ways-to-split-a-string
Description
Given a binary string s
(a string consisting only of '0's and '1's), we can split s
into 3 non-empty strings s1, s2, s3 (s1+ s2+ s3 = s).
Return the number of ways s
can be split such that the number of characters '1' is the same in s1, s2, and s3.
Since the answer may be too large, return it modulo 10^9 + 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"
Example 4:
**Input:** s = "100100010100110"
**Output:** 12
Constraints:
3 <= s.length <= 10^5
s[i]
is'0'
or'1'
.
ac
Last updated
Was this helpful?