You are given a string s consisting only of the characters ‘0’ and ‘1’. In one operation, you can change any ‘0’ to ‘1’ or vice versa.

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

Return the minimum number of operations needed to make s alternating.

Example 1:
Input: s = "0100"
Output: 1
Explanation: If you change the last character to ‘1’, s will be "0101", which is alternating.

Example 2:
Input: s = "10"
Output: 0
Explanation: s is already alternating.

Example 3:
Input: s = "1111"
Output: 2
Explanation: You need two operations to reach "0101" or "1010".

Constraints:

  • 1 <= s.length <= 104
  • s[i] is either ‘0’ or ‘1’.

Solution in python:

class Solution:
    def minOperations(self, s: str) -> int:
        count0 = 0
        count1 = 0
        flag0 = 0
        flag1 = 1
        for char in s:
            if int(char) != flag0:
                count0 += 1
            flag0 = 1 - flag0
            if int(char) != flag1:
                count1 += 1
            flag1 = 1 - flag1
        return min(count0, count1)
最后修改日期: 2021年3月23日

留言

撰写回覆或留言

发布留言必须填写的电子邮件地址不会公开。