Maison >développement back-end >Golang >Implémentation de l'algorithme de tri Golang

Implémentation de l'algorithme de tri Golang

PHPz
PHPzoriginal
2023-05-15 13:13:07633parcourir

L'algorithme de tri est l'un des algorithmes les plus fondamentaux dans le domaine de l'informatique. Il s'agit du processus de réorganisation d'un ensemble de données dans un ordre spécifique. Les algorithmes de tri courants incluent le tri à bulles, le tri par sélection, le tri par insertion, le tri rapide, etc. Cet article prendra le langage golang comme exemple pour présenter la mise en œuvre de plusieurs algorithmes de tri courants.

1. Bubble Sort

Bubble Sort est un algorithme de tri simple et intuitif. Il parcourt à plusieurs reprises la séquence à trier, compare deux éléments à la fois et échange leurs positions s'ils sont dans le mauvais ordre. Le processus de mise en œuvre spécifique est le suivant :

func bubbleSort(arr []int) []int {

n := len(arr)
for i := 0; i < n-1; i++ {
    for j := 0; j < n-i-1; j++ {
        if arr[j] > arr[j+1] {
            arr[j], arr[j+1] = arr[j+1], arr[j]
        }
    }
}
return arr

}

2. Selection Sort

Selection Sort est un algorithme de tri simple et intuitif, et son processus de mise en œuvre Sélectionnez le le plus petit (ou le plus grand) élément parmi les éléments de données à trier tour à tour, stockez-le au début de la séquence, puis continuez à trouver l'élément le plus petit (ou le plus grand) parmi les éléments non triés restants, puis placez-le à la fin triée de séquence. Le processus de mise en œuvre spécifique est le suivant :

func selectionSort(arr []int) []int {

n := len(arr)
for i := 0; i < n-1; i++ {
    minIndex := i
    for j := i + 1; j < n; j++ {
        if arr[j] < arr[minIndex] {
            minIndex = j
        }
    }
    arr[i], arr[minIndex] = arr[minIndex], arr[i]
}
return arr

}

3. Tri par insertion

Le tri par insertion (Tri par insertion) est un algorithme de tri simple et intuitif. idée Il insère les éléments de données à trier dans une séquence déjà triée en fonction de leur taille de clé. On suppose initialement que le premier élément de données forme lui-même une séquence ordonnée et que les éléments de données restants ne sont pas ordonnés. Le processus de mise en œuvre spécifique est le suivant :

func insertionSort(arr []int) []int {

n := len(arr)
for i := 1; i < n; i++ {
    tmp := arr[i]
    j := i - 1
    for ; j >= 0 && arr[j] > tmp; j-- {
        arr[j+1] = arr[j]
    }
    arr[j+1] = tmp
}
return arr

}

4. Tri rapide

Quick Sort (Quick Sort) est un algorithme de tri efficace qui utilise des méthodes auto-récursives Cette méthode décompose les éléments de données en ensembles plus petits d'éléments indépendants à des fins de tri. Le processus d'implémentation spécifique est le suivant :

func quickSort(arr []int) []int {

if len(arr) <= 1 {
    return arr
}
pivot := arr[0]
left, right := 0, len(arr)-1
for i := 1; i <= right; {
    if arr[i] < pivot {
        arr[left], arr[i] = arr[i], arr[left]
        left++
        i++
    } else if arr[i] > pivot {
        arr[right], arr[i] = arr[i], arr[right]
        right--
    } else {
        i++
    }
}
quickSort(arr[:left])
quickSort(arr[left+1:])
return arr

}

Ce qui précède est l'implémentation en langage Golang de quatre algorithmes de tri de base. Dans le processus de développement actuel, en fonction de la taille des données et de leurs caractéristiques, il est nécessaire de sélectionner un algorithme de tri approprié pour obtenir de meilleurs effets de tri.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn