Heim >Backend-Entwicklung >Golang >Tiefer Einblick: Array-Kreuzungsoperationen in Golang

Tiefer Einblick: Array-Kreuzungsoperationen in Golang

WBOY
WBOYOriginal
2024-04-04 09:45:01607Durchsuche

Es gibt drei Möglichkeiten, die Schnittmenge von Arrays in Golang zu ermitteln: Verwenden Sie Sprint und Scanf des fmt-Pakets, um das Array in einen String umzuwandeln und die Elemente in einem String zu finden, die einen anderen String enthalten. Verwenden Sie das Map-Paket, um eine Karte mit zu erstellen den Schlüssel als weiteres Array-Element in der Karte und prüfen Sie, ob das Element in der Karte vorhanden ist; verwenden Sie das Paket math/big, um das Array als große Ganzzahl zu speichern und logische Operatoren für Schnittpunktberechnungen zu verwenden.

深入探讨:Golang 中的数组交集操作

Deep Dive: Array-Schnittoperation in Golang

Array-Schnitt bedeutet, alle in einem Array enthaltenen Elemente in einem anderen Array zu finden. Dieser Artikel befasst sich mit drei Methoden zur Durchführung von Array-Schnittoperationen in der Go-Sprache und demonstriert deren Verwendung anhand eines praktischen Falls.

Methode 1: Sprint und Scanf im FMT-Paket

package main

import (
    "fmt"
    "strings"
)

func main() {
    // 数组 1
    a1 := []int{1, 2, 3, 4, 5}

    // 数组 2
    a2 := []int{2, 3, 5, 6, 7}

    // 转换数组 1 为字符串
    s1 := fmt.Sprint(a1)

    // 转换数组 2 为字符串
    s2 := fmt.Sprint(a2)

    // 寻找数组 1 字符串中的数组 2 元素,并删除重复项
    intersection := []int{}
    for _, v := range strings.Split(s2, " ") {
        if strings.Contains(s1, v) && !contains(intersection, v) {
            intersection = append(intersection, v)
        }
    }

    fmt.Println(intersection)  // 输出: [2 3 5]
}

// contains 函数检查元素 v 是否在数组 intersection 中
func contains(a []int, v int) bool {
    for _, x := range a {
        if x == v {
            return true
        }
    }
    return false
}

Methode 2: Kartenpaket

package main

import (
    "fmt"
    "strings"
)

func main() {
    // 数组 1
    a1 := []int{1, 2, 3, 4, 5}

    // 数组 2
    a2 := []int{2, 3, 5, 6, 7}

    // 创建一个映射,键为数组 2 中的元素,值为 true
    m := make(map[int]bool)
    for _, v := range a2 {
        m[v] = true
    }

    // 检查数组 1 中的元素是否也在映射中,并将其添加到交集中
    intersection := []int{}
    for _, v := range a1 {
        if m[v] {
            intersection = append(intersection, v)
        }
    }

    fmt.Println(intersection)  // 输出: [2 3 5]
}

Methode 3: Mathematik/großes Paket

package main

import (
    "fmt"
    "math/big"
)

func main() {
    // 数组 1
    a1 := []int{1, 2, 3, 4, 5}

    // 数组 2
    a2 := []int{2, 3, 5, 6, 7}

    // 使用 big.Int 存储大整数
    intersection := &big.Int{}

    set1 := new(big.Int)
    for _, v := range a1 {
        set1.SetUint64(uint64(v))
        intersection.Or(intersection, set1)
    }

    set2 := new(big.Int)
    for _, v := range a2 {
        set2.SetUint64(uint64(v))
        intersection.And(intersection, set2)
    }

    result := []int{}
    for i := 0; i < int(intersection.BitLen()); i++ {
        if intersection.Bit(uint(i)) == 1 {
            result = append(result, i+1)
        }
    }

    fmt.Println(result)  // 输出: [2 3 5]
}

Praktischer Fall: Überlappende Wörter in zwei Arrays finden

package main

import (
    "fmt"
    "strings"
)

func main() {
    // 数组 1:文章中的单词
    a1 := []string{"hello", "world", "golang", "programming", "language"}

    // 数组 2:用户搜索的关键词
    a2 := []string{"world", "javascript", "golang", "python"}

    // 使用 fmt 包中的 Sprint 和 Scanf
    intersection := []string{}
    for _, v := range a2 {
        if strings.Contains(strings.Join(a1, " "), v) && !contains(intersection, v) {
            intersection = append(intersection, v)
        }
    }

    fmt.Println(intersection)  // 输出: [world go lang]
}

Das obige ist der detaillierte Inhalt vonTiefer Einblick: Array-Kreuzungsoperationen in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn