Skip to content

Latest commit

 

History

History
66 lines (50 loc) · 2.57 KB

File metadata and controls

66 lines (50 loc) · 2.57 KB

< Previous                  Next >

Given a binary string s, return the minimum number of character swaps to make it alternating, or -1 if it is impossible.

The string is called alternating if no two adjacent characters are equal. For example, the strings "010" and "1010" are alternating, while the string "0100" is not.

Any two characters may be swapped, even if they are not adjacent.

 

Example 1:

Input: s = "111000"
Output: 1
Explanation: Swap positions 1 and 4: "111000" -> "101010"
The string is now alternating.

Example 2:

Input: s = "010"
Output: 0
Explanation: The string is already alternating, no swaps are needed.

Example 3:

Input: s = "1110"
Output: -1

 

Constraints:

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

Related Topics

[String] [Greedy]

Hints

Hint 1 Think about all valid strings of length n.
Hint 2 Try to count the mismatched positions with each valid string of length n.