2021-05-05:一个数组中只有两种字符‘G‘和‘B‘,可以让所有的G都放在左侧,所有的B都放在右侧。或者可以让所有的G都放在右侧,所有的B都放在左侧。但是只能在相邻字符之间进行交换操作。返回至少

首页 编程分享 PHP丨JAVA丨OTHER 正文

福大大架构师每日一题 转载 编程分享 2023-01-09 23:50:04

简介 2021-05-05:一个数组中只有两种字符’G’和’B’,可以让所有的G都放在左侧,所有的B都放在右侧。或者可以让所有的G都放在右侧,所有的B都放在左侧。但是只能在相邻字符之间进行交换操作。返回至少需要交换几次。 福大大 答案2021-05-05: 自然智慧...


2021-05-05:一个数组中只有两种字符’G’和’B’,可以让所有的G都放在左侧,所有的B都放在右侧。或者可以让所有的G都放在右侧,所有的B都放在左侧。但是只能在相邻字符之间进行交换操作。返回至少需要交换几次。

福大大 答案2021-05-05:

自然智慧即可。
所有G和所有B的相对顺序不变,交换次数一定是最少的。
相邻交换,类似于冒泡排序,而冒泡排序是稳定的。
把G全部移动到左边,记录次数step1;把B全部移动到左边,记录次数step2。返回值取step1和step2的最小值。

代码用golang编写。代码如下:

package main

import "fmt"

func main() {
   
    s := "BBGGB"
    ret := minSteps1(s)
    fmt.Println(ret)

    ret = minSteps2(s)
    fmt.Println(ret)
}

// 一个数组中只有两种字符'G'和'B',
// 可以让所有的G都放在左侧,所有的B都放在右侧
// 或者可以让所有的G都放在右侧,所有的B都放在左侧
// 但是只能在相邻字符之间进行交换操作,请问请问至少需要交换几次,
func minSteps1(s string) int {
   
    if len(s) == 0 {
   
        return 0
    }
    step1 := 0
    gi := 0
    for i := 0; i < len(s); i++ {
   
        if s[i] == 'G' {
   
            step1 += i - gi
            gi++
        }
    }
    step2 := 0
    bi := 0
    for i := 0; i < len(s); i++ {
   
        if s[i] == 'B' {
   
            step2 += i - (bi)
            bi++
        }
    }
    return getMin(step1, step2)
}

// 可以让G在左,或者在右
func minSteps2(s string) int {
   
    if len(s) == 0 {
   
        return 0
    }

    step1 := 0
    step2 := 0
    gi := 0
    bi := 0
    for i := 0; i < len(s); i++ {
   
        if s[i] == 'G' {
    // 当前的G,去左边 方案1
            step1 += i - gi
            gi++
        } else {
    // 当前的B,去左边 方案2
            step2 += i - bi
            bi++
        }
    }
    return getMin(step1, step2)
}

func getMin(a int, b int) int {
   
    if a < b {
   
        return a
    } else {
   
        return b
    }
}

执行结果如下:


左神java代码

转载链接:https://my.oschina.net/u/4553401/blog/5039069


Tags:


本篇评论 —— 揽流光,涤眉霜,清露烈酒一口话苍茫。


    声明:参照站内规则,不文明言论将会删除,谢谢合作。


      最新评论




ABOUT ME

Blogger:袅袅牧童 | Arkin

Ido:PHP攻城狮

WeChat:nnmutong

Email:nnmutong@icloud.com

标签云