Skip to content

Latest commit

 

History

History
67 lines (56 loc) · 1.87 KB

File metadata and controls

67 lines (56 loc) · 1.87 KB

1864. 构成交替字符串需要的最小交换次数

给你一个二进制字符串 s ,现需要将其转化为一个 交替字符串 。请你计算并返回转化所需的 最小 字符交换次数,如果无法完成转化,返回 -1

交替字符串 是指:相邻字符之间不存在相等情况的字符串。例如,字符串 "010""1010" 属于交替字符串,但 "0100" 不是。

任意两个字符都可以进行交换,不必相邻

示例 1:

输入: s = "111000"
输出: 1
解释: 交换位置 1 和 4:"111000" -> "101010" ,字符串变为交替字符串。

示例 2:

输入: s = "010"
输出: 0
解释: 字符串已经是交替字符串了,不需要交换。

示例 3:

输入: s = "1110"
输出: -1

提示:

  • 1 <= s.length <= 1000
  • s[i] 的值为 '0''1'

题解 (Rust)

1. 题解

impl Solution {
    pub fn min_swaps(s: String) -> i32 {
        let zeros = s.chars().filter(|&c| c == '0').count();
        let ones = s.len() - zeros;
        let mut ret0 = i32::MAX;
        let mut ret1 = i32::MAX;

        if zeros == ones || zeros == ones + 1 {
            ret0 = s
                .bytes()
                .enumerate()
                .filter(|&(i, c)| (i % 2) as u8 + b'0' != c)
                .count() as i32
                / 2;
        }
        if zeros == ones || zeros + 1 == ones {
            ret1 = s
                .bytes()
                .enumerate()
                .filter(|&(i, c)| (i % 2) as u8 + b'0' == c)
                .count() as i32
                / 2;
        }

        if ret0 == i32::MAX && ret1 == i32::MAX {
            return -1;
        }

        ret0.min(ret1)
    }
}