当前位置:   article > 正文

力扣1864-构成交替字符串需要的最小交换次数(JavaScript)_最小交换次数javascript

最小交换次数javascript
var minSwaps = function(s) {
    let odd = 0, even = 0;
    // 求‘1’出现在奇数位和偶数位的次数
    for(let i = 0; i < s.length; i++) {
        if(s[i] === '1') {
            if(i % 2 === 0) even++;
            else odd++;
        }
    }
    // “1”和“0”的总数
    let one = odd + even;
    let zero = s.length - odds;
    // 可以进行交换的字符串中“1”和“0”的数量差最大为1
    if(Math.abs(one - zero) > 1) return -1;
    else if(one === zero) return Math.min(odd, even);
    // 如果“0”的数量更多,那么“1”应该出现在奇数位,及需要交换偶数位上的‘1’
    else if(one < zero) return even;
    // 如果“1”的数量更多,那么“1”应该出现在偶数位,及需要交换奇数位上的‘1’
    else if(one > zero) return odd;
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/588083
推荐阅读
相关标签
  

闽ICP备14008679号