You are given a binary string s and two integers encCost and flatCost.
For each index i, s[i] = '1' indicates that the ith element is sensitive, and s[i] = '0' indicates that it is not.
The string must be partitioned into segments. Initially, the entire string forms a single segment.
For a segment of length L containing X sensitive elements:
X = 0, the cost is flatCost.X > 0, the cost is L * X * encCost.If a segment has even length, you may split it into two contiguous segments of equal length and the cost of this split is the sum of costs of the resulting segments.
Return an integer denoting the minimum possible total cost over all valid partitions.
Example 1:
Input: s = "1010", encCost = 2, flatCost = 1
Output: 6
Explanation:
s = "1010" has length 4 and contains 2 sensitive elements, giving a cost of 4 * 2 * 2 = 16."10" and "10". Each segment has length 2 and contains 1 sensitive element, so each costs 2 * 1 * 2 = 4, giving a total of 8."1", "0", "1", and "0". A segment containing "1" has length 1 and exactly one sensitive element, giving a cost of 1 * 1 * 2 = 2, while a segment containing "0" has no sensitive elements and therefore costs flatCost = 1.2 + 1 + 2 + 1 = 6, which is the minimum possible total cost.Example 2:
Input: s = "1010", encCost = 3, flatCost = 10
Output: 12
Explanation:
s = "1010" has length 4 and contains 2 sensitive elements, giving a cost of 4 * 2 * 3 = 24."10" and "10".2 * 1 * 3 = 6, giving a total of 12, which is the minimum possible total cost.Example 3:
Input: s = "00", encCost = 1, flatCost = 2
Output: 2
Explanation:
The string s = "00" has length 2 and contains no sensitive elements, so storing it as a single segment costs flatCost = 2, which is the minimum possible total cost.
Constraints:
1 <= s.length <= 105s consists only of '0' and '1'.1 <= encCost, flatCost <= 105Loading editor...
"1010" 2 1