duanlu9816 2019-07-12 13:19
浏览 373
已采纳

Golang从所有数组中存在的值创建数组

I need to create an array from multiple arrays. The new array must only contain the values that is present in all arrays passed in. For example.

array1 := []string{"hello", "germany", "brasil", "fiji"}
array2 := []string{"goodbye", "germany", "brasil", "fiji"}
array3 := []string{"hello", "brasil", "fiji"}
array4 := []string{"hello", "brasil", "fiji", "usa"}

func mergeArrays(arrs ...[]string) []string{
   // process arrays
}

myNewArray := mergeArrays(array1,array2,array3,array4)
fmt.Println(myNewArray) // ["fiji", "brasil"]

The example should return ["fiji", "brasil"] since they are the only values present in all arrays.

How could I go about writing a function that could achieve such a goal in golang?

This is my attempt but feels a bit clumsy

func mergeArrays(arrs ...[]string) []string {
    var finalArr []string
    if len(arrs) == 0 {
        return finalArr
    }

    for i, a := range arrs {
        if i == 0 {
            finalArr = arrs[0]
            continue
        }
        for i, e := range finalArr {
            if !strContains(a, e) {
                finalArr = append(finalArr[:i], finalArr[i+1:]...)
            }
        }

    }

    return finalArr
}

func strContains(s []string, e string) bool {
    for _, a := range s {
        if a == e {
            return true
        }
    }
    return false
}

Playground link: https://play.golang.org/p/KRygw7OVBbn

  • 写回答

2条回答 默认 最新

  • duan1443 2019-07-12 14:36
    关注

    Per my comment above, here's one way to do it with go maps and thus avoid iterating over potentially large slices:

    func itemize(a []string) map[string]struct{} {
        m := make(map[string]struct{})
        for _, v:=range a {
            m[v] = struct{}{} // struct{}{} == an empty struct (i.e. a value that incurs no storage)
        }
        return m
    }
    
    func commonElements(arrs ...[]string) (results []string) {
        if len(arrs) == 0 {
            return // edge case
        }
    
        mm := itemize(arrs[0]) // master map
    
        for i:=1; i<len(arrs);i++ {
            m := itemize(arrs[i]) // current map
            for k := range mm {
                if _, ok := m[k]; !ok {
                    delete(mm, k) // master item not in current slice, so remove from master
                }
            }
        }
    
        results = make([]string, len(mm)) // make a precisely sized slice...
        i:=0
        for k := range mm {
            results[i] = k // so we can insert results directly into it without using append
            i++ 
        }
    
        return
    }
    

    https://play.golang.org/p/pTaXR-nY9zm

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私